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NEW APPLICATION TRANSMITTAL 



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 



Box Patent Application 

Assistant Commissioner for Patents 

Washington, D.C. 20231 



NEW APPLICATION TRANSMITTAL 



Transmitted herewith for filing is the patent application of HOME NETWORK DEVICE 
INFORMATION ARCHITECTURE 

Inventor(s): Dongyan Wang and Richard Humpleman 

WARNING: 

37 CFH § 7.47 (a)(1) points out: 

"(a) A Patent is applied for in the name or names of the actual inventor or inventors. 
"(1) The inventorship of a nonprovisional application is that inventorship set forth in the oath or 
declaration as prescribed by § 1,63, except as provided for in § 7.53 (d)(4) and § 1.63(d). If an 
oath or declaration as prescribed by § 1.63 is not filed during the pendency of a nonprovisional 
application, the inventorship is that inventorship set forth in the application papers filed pursuant 
to § 1.53 (b), unless a petition under this paragraph accompanied by the fee set forth in § 7. 7 7(i) 
is fifed supplying or changing the name or names of the inventor or inventors. " 

For (title): 



1 . Type of Application 

This new application is for a(n) 



(check one applicable item befow) 



[X] Original (nonprovisional) 



[ ] Design 



[ ] Plant 
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WARNING: Do not use this transmittal for a completion in the U.S. of an International 
Application under 35 U.S.C. 371(c)(4), unless the International Application is 
being filed as a divisional, continuation or continuation-in-part application. 

WARNING: Do not use this transmittal for the filing of a provisional application. 

NOTE: If one of the following 3 items apply then complete and attach ADDED PAGES FOR 
NEW APPLICATION TRANSMITTAL WHERE BENEFIT OF A PRIOR U.S. APPLICATION 
CLAIMED and a NOTIFICATION IN PARENT APPLICATION OF THE FILING OF THIS 
CONTINUATION APPLICATION. 

[ ] Divisional 

[ ] Continuation 

[ ] Continuation-in-part (C-l-P) 



2. Benefit of Prior U.S. Appiication(s) 



NOTE: A nonprovisional application may claim an invention disclosed in one or more prior 
filed copending nonprovisional applications or copending international applications 
designating the United States of America. In order for a nonprovisional application 
to claim the benefit of a prior filed copending nonprovisional application or copending 
international application designating the United States of America, each prior 
application must name as an inventor at least one inventor named in the later filed 
nonprovisional application and disclose the named inventor's invention claimed in at 
least one claim of the later filed nonprovisional application in the manner provided by 
the first paragraph of 35 U.S.C. 1 1 2. Each prior application must also be: 
{i) An international application entitled to a filing date in accordance with PCT Article 
1 1 and designating the United States of America; or 

(ii) Complete as set forth in § 1.51(b); or 

(iii) Entitled to a filing date as set forth in § 1 .53(b) or § 1 .53(d) and include the basic 
filing fee set forth in § 1 . 1 6; or 

(iv) Entitled to a filing date as set forth in § 1.53(b) and have paid therein the 
processing and retention fee set forth in § 1 .21 (I) within the time period set forth in 
§ 1.53(f). 

37 CFR § 1.78(a)(1). 

NOTE: If the new application being transmitted is a divisional, continuation or a 
continuation-in-part of a parent case, or where the parent case is an International 
Application which designated the U.S., or benefit of a prior provisional application 
is claimed, then check the following item and complete and attach ADDED PAGES 
FOR NEW APPLICATION TRANSMITTAL WHERE BENEFIT OF PRIOR U.S. 
APPLICATIONS) CLAIMED. 
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WARNING: 

If an application claims the benefit of the filing date of an earlier filed application under 35 U.S.C. 
1 20, 121 or 365(c), the 20-year term of that application will be based upon the filing date of the 
earliest U.S. application that the application makes reference to under 35 U.S.C. 120,121 or 
365(c) (35 U S.C. 1 54(a)(2) does not take into account, for the determination of the patent term, 
any application on which priority is claimed under 35 U.S.C. 119, 365(a) or 365(b)). For a c-i-p 
application, applicant should review whether any claim in the patent that will issue is supported 
by an earlier application and, if not, the applicant should consider canceling the reference to the 
earlier filed application. The term of a patent is not based on a claim-by-claim approach. See 
Notice of April 14, 1995, 60 Fed. Reg. 20, 195, at 20,205. 



WARNING: 

When the last day of pendency of a provisional application falls on a Saturday, Sunday, or Federal 
holiday within the District of Columbia, any nonprovisional application claiming benefit of the 
provisional application must be filed prior to the Saturday, Sunday, or Federal holiday within the 
District of Columbia. See 37 CFR § 1.78(a)(3). 

[X] The new application being transmitted claims the benefit of prior U.S. application(s). 
Enclosed are ADDED PAGES FOR NEW APPLICATION TRANSMITTAL WHERE 
BENEFIT OF PRIOR U.S. APPLICATION(S) CLAIMED. 



3. Papers Enclosed 

A. Required For Filing Date Under 37 § CFR 1.53(b) (Regular) or 37 § CFR 1.153 
(Design) Application 



Pages of Specification 53 
Pages of Claims 06 
Sheets of Drawing 1 2 



WARNING: 

DO NOT submit original drawings. A high quality copy of the drawings should be supplied when 
filing a patent application. The drawings that are submitted to the Office must be on strong, white, 
smooth, and non-shiny paper and meet the standards according to § 1 .84. If corrections to the 
drawings are necessary, they should be made to the original drawing and a high-quality copy of the 
corrected original drawing then submitted to the Office. Only one copy is required or desired. For 
comments or proposed then-new 37 CFR 1.84, see Notice of March 9, 1988 (1990 O.G. 57-62). 

NOTE: "Identifying indicia, if provided, should include the application number or the title 
of the invention, inventor's name, docket number (if any), and the name and telephone 
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number of a person to call if the Office is unable to match the drawings to the proper 
application. This information should be placed on the back of each sheet of drawing a 
minimum distance of 1 .5 cm. (5/8 inch) down from the top of the page ..."37 CFR 1 .84 
(c)). 

{complete the following, if applicable) 

[ ] The enclosed drawing(s) are photograph(s), and there is also attached a "PETITION 

TO ACCEPT PHOTOGRAPH(S) AS DRAWING(S)." 37 CFR 1.84(b). 
[ ] formal 
[X] informal 

B. Other Papers Enclosed X 

Pages of declaration and power of attorney 2 
Pages of abstract 1 
Other Appendix - 8 Pages 
Assignment and Cover Sheet 5 



4. Additional papers enclosed 

[ ] Amendment to claims 

[ ] Cancel in this applications claims before calculating the filing fee. 

(At least one original independent claim must be retained for filing 
purposes.) 

[ ] Add the claims shown on the attached amendment. (Claims added have 
been numbered consecutively following the highest numbered original 
claims.) 

[ ] Preliminary Amendment 

[ ] Information Disclosure Statement (37 CFR 1.98) 

[ ] Form PTO-1449 (PTO/SB/08A and 08B) 

[ ] Citations 
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[ ] Declaration of Biological Deposit 

[ ] Submission of "Sequence Listing," computer readable copy and/or amendment 
pertaining thereto for biotechnology invention containing nucleotide and/or 
amino acid sequence. 

[ ] Authorization of Attorney(s) to Accept and Follow Instructions from 
Representative 

[ ] Special Comments 

[ ] Other 



5. Declaration or oath (including power of attorney) 

NOTE: A newly executed declaration is not required in a continuation or divisional 
application provided that the prior nonprovisional application contained a 
declaration as required, the application being filed is by all or fewer than all the 
inventors named in the prior application, there is no new mater in the application 
being filed, and a copy of the executed declaration filed in the prior application 
(showing the signature or an indication thereon that it was signed) is submitted. 
The copy must be accompanied by a statement requesting deletion of the names 
of person(s) who are not inventors of the application being filed. If the 
declaration in the prior application was filed under § 1 .47, then a copy of that 
declaration must be filed accompanied by a copy of the decision granting § 1 .47 
status or, if a nonsigning person under § 1 .47 has subsequently joined in a prior 
application, then a copy of the subsequently executed declaration must be filed. 
See 37 CFR §§ 1.63(d) (1)~(3). 

NOTE: A declaration filed to complete an application must be executed, identify the 
specification to which it is directed, identify each inventor by full name including 
family name and at least one given name, without abbreviation together with 
any other given name or initial, and the residence, post office address and 
country or citizenship of each inventor, and state whether the inventor is a sole 
or joint inventor. 37 CFR § 1 .63(a)(1)-{4). 

[X] Enclosed, 

executed by (check all applicable boxes) 

[X] inventor(s). 

[ ] legal representative of inventor(s). 37 CFR 1.42 or 1 .43 
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[ ] joint inventor or person showing a proprietary interest on behalf of inventor who 
refused to sign or cannot be reached. 

[ ] this is the petition required by 37 CFR 1 .47 and the statement required by 
37 CFR 1 .47 is also attached. 

See item 13 beiow for fee. 
[ ] Not Enclosed. 

NOTE: Where the filing is a completion in the U.S. of an International Application 
or where the completion of the U.S. application contains subject matter in 
addition to the International Application, the application may be treated as 
a continuation or continuation-in-part, as the case may be, utilizing ADDED 
PAGE FOR NEW APPLICATION TRANSMITTAL WHERE BENEFIT OF PRIOR 
U.S. APPLICATION CLAIMED. 

[ ] Application is made by a person authorized under 37 CFR 1 .41 (c) on behalf of 
all the above named inventor(s). 

(The declaration or oath, along with the surcharge required by 37 CFR 1.16(e) 

can be filed subsequently). 

[ ] Showing that the filing is authorized. 

(not required unless called into question. 37 CFR 1.41(d)). 
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6. Inventorship Statement 
WARNING: 

If the named inventors are each not the inventors of all the claims an explanation, including the 
ownership of the various claims at the time the last claimed invention was made, should be 
submitted. 

The inventorship for all the claims in this application are: 
[X] The same. 

or 

[ ] Not the same. An explanation, including the ownership of the various claims at the 
time the Jast claimed invention was made, 

[ ] is submitted. 

[ ] will be submitted. 



7. Language 

NOTE: An application including a signed oath or declaration may be filed in a language other 
than English. An English translation of the non-English language application and the 
processing fee of $130.00 required by 37 CFR 1 .17(k) is required to be filed with the 
application, or within such time as may be set by the Office. 37 CFR 1 .52(d). 

[X] English 

[ ] Non-English 

[ ] The attached translation includes a statement translation and is accurate. 37 
CFR 1.52(d). 
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8. Assignment 

[X] An assignment of the invention to Samsung Electronics, Co., Ltd. 

[X] is attached. A separate [X] "COVER SHEET FOR ASSIGNMENT (DOCUMENT) 
ACCOMPANYING NEW PATENT APPLICATION" or [ ] FORM TO 1 595 is also 
attached. 

[ ] will follow. 

NOTE: "If an assignment is submitted with a new application, send two separate letters - one 
for the application and one for the assignment." Notice of May 4, 1990 (1114 O.G. 77-78). 

WARNING: 

A newly executed "CERTIFICATE UNDER 37 CFR 3.73(b)" must be filed when a continuation-in- 
part application is filed by an assignee. Notice of April 30, 1993, 1 150 O.G. 62-64. 



9. Certified Copy 



Certified copy(ies) of application(s): 



Country 


ADDln. 


No. 


Filed 


* 

Country 


ADDln. 


No. 


Filed 


* 

Country 


Aonln. 


No. 


Filed 



* 



from which priority is claimed 

[ ] is/(are) attached 
[ ] will follow. 

NOTE: The foreign application forming the basis for the claim for priority must be referred to 
in the oath or declaration. 37 CFR 1 .55(a) and 1 .63. 

NOTE: This item is for any foreign priority for which the application being filed directly 
relates. If any parent U.S. application or International Application from which this 
application claims benefit under 35 U.S.C. 1 20 is itself entitled to priority from a prior 
foreign application, then complete item 18 on the ADDED PAGES FOR NEW 
APPLICATION TRANSMITTAL WHERE BENEFIT OF PRIOR U.S. APPLICATION(S) 
CLAIMED. 
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10. Fee Calculation (37 CFR 1.16) 



[X] Regular Application 
CLAIMS AS FILED 



Number Filed 


Number Extra 


Rate 


Basic Fee 

37 CFR 1.16(a) 








$ 


690.00 


Total Claims 










(37 CFR 1.16(c)) 28 


-20= 8 X 


$ 18.00 


$ 


144.00 


Independent Claims 

(37 CFR 1.16(b)) 3 


-3= 0 X 


$ 78.00 


$ 


0.00 


Multiple dependent claim(s), 
if any (37 CFR 1.16(d)) 


+ 


$260.00 


$ 




[ ] Amendment canceling extra claims enclosed. 









[ ] Amendment deleting multiple dependencies enclosed. 
[ ] Fee for extra claims is not being paid at this time. 

NOTE: If the fees for extra claims are not paid on filing they must be paid or the claims 
canceled by amendment, prior to the expiration of the time period set for response 
by the Patent and Trademark Office in any notice of fee deficiency. 37 CFR 1 . 1 6(d) . 



B. 

[ ] 



C. 

[ ] 



Design Application 
($310.00-37 CFR 1.16(f)) 



Plant Application 
($480.00-37 CFR 1.16(g)) 



Filing Fee Calculation 



Filing Fee Calculation 



Filing Fee Calculation 



834.00 
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1 1 . Small Entity Statement(s) 



[ ] Statement(s) that this is a filing by a small entity under 37 CFR 1 .9 and 1 .27 is (are) 
attached. 



WARNING: 



"Status as a small entity must be specifically established in each application or patent in which 
the status is available and desired. Status as a small entity in one application or patent does not 
affect any other application or patent, including applications or patents which are directly or 
indirectly dependent upon the application or patent in which the status has been established. The 
refiling of an application under § 1 .53 as a continuation, division, or continuation-in-part (including 
a continued prosecution application under § 1 .53 (d)), or the filing of a reissue application requires 
a new determination as to continued entitlement to small entity status for the continuing or reissue 
application. A nonprovisional application claiming benefit under 35 U.S.C. 119(e), 120,121, or 
365(c) of a prior application, or a reissue application may rely on a statement filed in the prior 
application or in the patent if the nonprovisional application or the reissue application includes a 
reference to the statement in the prior application or in the patent or includes a copy of the 
statement in the prior application or in the patent and status as a small entity is still proper and 
desired. The payment of the small entity basic statutory filing fee will be treated as such a 
reference for purposes of this section." 37 CFR § 1.28(a)(2). 

(complete the following, if applicable) 

[ ] Status as a small entity was claimed in prior application 

/ , filed on , from which benefit is 

being claimed for this application under: 



35 U.S.C. [ ] 119(e), 
[ ] 120, 
[ ] 121, 
[ ] 365(c), 

and which status as a small entity is still proper and desired. 



[ ] A copy of the statement in the prior application is included. 



Filing Fee Calculation {50% of A, B or C above) 



$ 



NOTE: Any excess of the full fee paid will be refunded if small entity status is established 
and a refund request are filed within 2 months of the date of timely payment of a full 
fee. The two-month period is not extendable under § 7. 136. 37 CFR 1.28(a). 
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12. Request for International-Type Search (37 CFR 1.104(d)) 

(complete, if applicable) 

[ ] Please prepare an international-type search report for this application at the time 
when national examination on the merits takes place. 



1 3. Fee Payment Being Made At This Time 

[ ] Not Enclosed. 

[ ] No filing fee is to be paid at this time. 
(This and the surcharge required by 37 CFR 1.16(e) can be paid subsequently.) 

[X] Enclosed 

[X] Filing fee 
[X] Recording assignment 

($40.00; 37 CFR 1.21(h)) 

(See attached COVER SHEET FOR ASSIGNMENT 
ACCOMPANYING NEW APPLICATION) 
[ ] Petition fee for filing by other than all the 
inventors or person on behalf of the inventor 
where inventor refused to sign or cannot be 
reached. ($130.00; 37 CFR 1.47 and 1.1 7(i)) 

[ ] For processing an application with a 
specification in a non-English language. 
($130.00; 37 CFR 1.52(d) and 1.1 7(k)) 

[ ] Processing and retention fee 

($130.00; 37 CFR 1.53(d) and 1.21(1)) 

[ ] Fee for international-type search report 
($40.00; 37 CFR 1.21(e)) 

NOTE: 37 CFR 1 .21 (I) establishes a fee for processing and retaining any application that is 
abandoned for failing to complete the application pursuant to 37 CFR 1 . 53(f) and this, 
as well as the changes to 37 CFR 1 .53 and 1 .78(a)(1), indicate that in order to obtain 
the benefit of a prior U.S. application, either the basic filing fee must be paid, or the 
processing and retention fee of § 1 .21 (I) must be paid within 1 year from notification 
under § 53(f). 

Total fees enclosed $ 874.00 



$ 834.00 

$ 40.00 

$ 

$ 

$ 

$ 
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1 4. Method of Payment of Fees 



[X] Check in the amount of $ 874.00 

[ ] Charge Account No. 1 9-1 995 in the amount of $ . A duplicate of this 

transmittal is attached. 

NOTE: Fees should be itemized in such a manner that it is clear for which purpose the fees 
are paid. 37 CFR 1.22(b). 



15. Authorization to Charge Additional Fees 



WARNING: 



If no fees are to be paid on filing, the following items should not be completed. 



WARNING: 



Accurately count claims, especially multiple dependent claims, to avoid unexpected high charges, 
if extra claim charges are authorized. 



[X] The Commissioner is hereby authorized to charge the following additional fees by this 
paper and during the entire pendency of this application to Account No. 1 9-1 995 . 



[X] 37 CFR 1.16(a), (f) or (g) (filing fees) 

[ ] 37 CFR 1.16(b), (c) and (d) (presentation of extra claims) 

NOTE: Because additional fees for excess or multiple dependent claims not paid on 

filing or on later presentation must only be paid or these claims canceled by 
amendment prior to the expiration of the time period set for response by the 
PTO in any notice of fee deficiency (37 CFR 1.16(d)), it might be best not to 
authorize the PTO to charge additional claim fees, except possibly when dealing 
with amendments after final action. 



[ ] 37 CFR 1 .16(e), (surcharge for filing the basic filing fee and/or declaration on a 
date later than the filing date of the application) 



[ ] 37 CFR §§1.17(a){1)-(5) (extension fees pursuant to § 1.136(a)). 



[ ] 37 CFR 1.17(a)(1)-(5) (application processing fees) 
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NOTE: "... A written request may be submitted in an application that is an 
authorization to treat any concurrent or future reply, requiring a petition for 
an extension of time under this paragraph for its timely submission, as 
incorporating a petition for extension of time for the appropriate length of 
time. An authorization to charge all required fees, fees under § 1 .1 7, or all 
required extension of time fees will be treated as a constructive petition for 
an extension of time in any concurrent or future reply requiring a petition 
for an extension of time under this paragraph for its timely submission. 
Submission of the fee set forth in § 1.17(a) will also be treated as a 
constructive petition for an extension of time in any concurrent reply 
requiring a petition for an extension of time under this paragraph for its 
timely submission." 37 CFR § 1.136(a)(3). 

[ ] 37 CFR 1 .18 (issue fee at or before mailing of Notice of Allowance, pursuant to 
37 CFR 1.311 (b). 

NOTE: Where an authorization to charge the issue fee to a deposit account has been 

filed before the mailing of a Notice of Allowance, the issue fee will be 
automatically charged to the deposit account at the time of mailing the notice 
of allowance. 37 CFR 1 .31 1 (b). 



NOTE: 37 CFR 1.28(b) requires "Notification of any change in status resulting in loss 

of entitlement to small entity status must be filed in the application.. .prior to 
paying, or at the time of paying. ..the issue fee..." From the wording of 
37 CFR 1.28(b): (a) notification of change of status must be made even if the 
fee is paid as "other than a small entity"; and (b) no notification is required if the 
change is to another small entity. 
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16. Instructions As To Overpayment 

NOTE: "... Amounts of twenty-five dollars or less will not be returned unless specifically 
requested within a reasonable time, nor will the payer be notified of such amounts; 
amounts over twenty-five dollars may be returned by check or, if requested, by credit 
to a deposit account." 37 CFR § 1.26(a). 

[X] Credit Account No. 19-1995 
[ ] Refund 



SIGNATURE OF PRACTITIONER 




Tel. No. (310) 789-3200 




SHERMAN & SHERMAN 
2629 Century Park East 
Seventeenth Floor 
Los Angeles, California 90067 
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CERTIFICATION UNDER 37 CFR 1.10 



I hereby certify that this New Application Transmittal and the documents referred to as attached 
therein are being deposited with the United States Postal Service on this date June 1 2, 2000 in 
an envelope as "Express Mail Post Office to Addressee" Mailing Label Number P:U<>G£?IW2$ Z (J$ 
addressed to: Box Patent Application, Assistant Commissioner for Patents, Washington, D. C. 
20231. 



e or Drinf name of person 



(Type or print name of person mailing paper) 



(Signature of/person mailincjjaaper) 



WARNING: 

Certificate of mailing (first class) or facsimile transmission procedures of 37 CFR 1.8 cannot be 
used to obtain a date of mailing or transmission for this correspondence. 

WARNING: 

Each paper or fee filed by "Express Mail" must have the number of the "Express Mail" mailing label 
placed thereon prior to mailing. 37 CFR 1 .10(b). 

"Since the filing of correspondence under §1.10 without the Express Mail mailing label thereon 
is an oversight than can be avoided by the exercise of reasonable care, requests for waiver of this 
requirement will not be granted on petition." Notice of Oct. 24, 1996, 60 Fed. Reg. 56,439, at 
56,442. 
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[X] Incorporation by reference of added pages 

(Check the following item if the application in this transmittal claims the benefit of 
prior U.S. application(s) (including an international application entering the U.S. stage 
as a continuation, divisional or C-l-P application) and complete and attach the ADDED 
PAGES FOR NEW APPLICATION TRANSMITTAL WHERE BENEFIT OF PRIOR U.S. 
APPLICATION(S) CLAIMED). 

[X] Pius Added Pages for New Application Transmittal Where Benefit Of Prior U.S. 
Application(s) Claimed 

Number of pages added __8 . 



Plus Added Pages for Papers Referred To In Item 4 Above 

Number of pages added 



[ ] Plus Added Pages deleting names of inventor(s) named in prior application(s) who 
is/are no longer inventor(s) of the subject matter claimed in this application. 

Number of pages added __ . — 

[ ] Plus "Assignment Cover Letter Accompanying New Application" 

Number of pages added 

[ ] Statement Where No Further Pages Added 

(If no further pages form a part of this transmittal, then end this transmittal with this 
page and check the following item) 

[ ] This transmittal ends with this page. 
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ADDED PAGE{S) FOR SPECIAL COMMENTS FOR NEW APPLICATION 

TRANSMITTAL 



Added page 1 
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Page 1/8 



ADDED PAGES FOR APPLICATION TRANSMITTAL WHERE 
BENEFIT OF PRIOR U.S. APPLICATION(S) CLAIMED 



NOTE: See37C.F.R. §178. 



17. Relate Back 
WARNING: 

If an application claims the benefit of the filing date of an earlier filed application under 35 U.S.C. §§ 120, 
121 or 365(c) the 20-year term of that application will be based upon the filing date of the earliest U.S. 
application that the application makes reference to under 35 U.S.C. §§ 120, 121 or 365(c) . (35 U.S.C. § 
1 54(a)(2) does not take into account, for the determination of the patent term, any application on which 
priority is claimed under 35 U.S.C. §§119, 365(a) or 365(b) .) For a c-i-p application, applicant should 
review whether any claim in the patent that will issue is supported by an earlier application and, if not, the 
applicant should consider canceling the reference to the earlier filed application. The term of a patent is 
not based on a claim-by-claim approach. See Notice of April 14, 1995, 60 Fed. Reg. 20,195, at 20,205. 

(complete the following, if applicable) 

[X] Amend the specification by inserting, before the first line, the following sentence: 
A. 35 U.S.C. § 119(e) 

NOTE: "Any nonprovisional application claiming the benefit of one or more prior filed copending 
provisional applications must contain or be amended to contain in the first sentence of the 
specification following the title a reference to each such prior provisional application, identifying it 
as a provisional application, and including the provisional application number (consisting of series 
code and serial number)." 37 C.F.R. § 1.78(a)(4). 

[X] "This application claims the benefit of U.S. Provisional Application(s) No(s).: 



APPLICATION NO(S). 

60/146,101 

60/149,515 



FILING DATE 
July 27, 1999 
August 17, 1999 
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BENEFIT OF PRIOR U.S. APPLICATION(S) CLAIMED 



B. 35 U.S.C. §§ 120, 121 and 365(c) 



NOTE: "Except for a continued prosecution application filed under § 1 .53(d), any nonprovisional 

application claiming the benefit of one or more prior filed copending nonprovisional applications or 
international applications designating the United States of America must contain or be amended 
to contain in the first sentence of the specification following the title a reference to each such prior 
application, identifying it by application number (consisting of the series code and serial number) 
or international application number and international filing date and indicating the relationship of 
the applications. ... Cross-references to other related applications may be made when 
appropriate." (See § 1.14(a)). 37 C.F.R. § 1.78(a)(2). 



[ ] "This application is a 

[ ] continuation 



[ ] continuation-in-part 



[ ] divisional 



of copending application(s) 



[ ] 
[ ] 



Application No. 
Application No. 



filed on 
filed 



which is a continuation of 



International Application , 
designated the U.S." 



filed on 



and which 



NOTE: The proper reference to a prior filed PCT application that entered the U.S. national phase 

is the U.S. serial number and the filing date of the PCT application that designated the 
U.S. 

NOTE: (1) Where the application being transmitted adds subject matter to the International 

Application, then the filing can be as a continuation-in-part or (2) if it is desired to do so for 
other reasons then the filing can be as a continuation. 

NOTE: The deadline for entering the national phase in the U.S. for an international application 

was clarified in the Notice of April 28, 1987 (1079 O.G. 32 to 46) as follows: 

"The Patent and Trademark Office considers the International application to be pending 
until the 22nd month from the priority date if the United States has been designated and 
no Demand for International Preliminary Examination has been filed prior to the expiration 
of the 19th month from the priority date and until the 32nd month from the priority date if a 
Demand for International Preliminary Examination which elected the United States of 
America has been filed prior to the expiration of the 19th month from the priority date, 
provided that a copy of the international application has been communicated to the Patent 
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and Trademark Office within the 20 or 30 month period respectively. If a copy of the 
international application has not been communicated to the Patent and Trademark Office 
within the 20 or 30 month period respectively, the international application becomes 
abandoned as to the United States 20 or 30 months from the priority date respectivley. 
These periods have been placed in the rules as paragraph (h) of § 1.494 and paragraph 
(i) of § 1.495. A continuing application under 35 U.S.C. 365(c) and 120 may be filed 
anytime during the pendency of the international application." 

[ ] "The nonprovisional application designated above, namely application 

/ , filed , claims the benefit of 

U.S. Provisional Application(s) No(s).: 



APPLICATION NO(S).: FILING DATE 



[ ] Where more than one reference is made above, please combine all references 
into one sentence. 



18. Relate Back-35 U.S.C. § 119 Priority Claim for Prior Application 

The prior U.S. application(s), including any prior International Application 
designating the U.S., identified above in item 17B, in turn itself claim(s) foreign 
priority(ies) as follows: 



Country Appln. No. Filed on 



The certified copy(ies) has (have) 
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[ ] been filed on , in prior application 0 / , which was filed 

on ■ 

[ ] is (are) attached. 

WARNING: 

The certified copy of the priority application that may have been communicated to the PTO by the 
International Bureau may . 
not be relied on without any need to file a certified copy of the priority application in the continuing 
application This is so because the certified copy of the priority application communicated by the 
International Bureau is placed in a folder and is not assigned a U.S. serial number unless the national 
stage is entered. Such folders are disposed of if the national stage is not entered. Therefore, such certified 
copies may not be available if needed later in the prosecution of a continuing application. An alternative 
would be to physically remove the priority documents from the folders and transfer them to the continuing 
application. The resources required to request transfer, retrieve the folders, make suitable record 
notations transfer the certified copies, enter and make a record of such copies in the Continuing 
Application are substantial. Accordingly, the priority documents in folders of international applications that 
have not entered the national stage may not be relied on. Notice of April 28, 1987 (1079 O.G. 32 to 46). 



1 9. Maintenance of Copendency of Prior Application 

NOTE- The PTO finds it useful if a copy of the petition filed in the prior application extending the 

term for response is filed with the papers constituting the filing of the continuation 
application. Notice of November 5, 1985 (1060 O.G. 27). 

A. [] Extension of time in prior application 

(This item must be completed and the papers filed in the prior application, if the 
period set in the prior application has run.) 

[ ] A petition, fee and response extends the term in the pending prior application 
until • 

[ ] A copy of the petition filed in prior application is attached. 



[ ] Conditional Petition for Extension of Time in Prior Application 
(complete this item, if previous item not applicable) 

[ ] A conditional petition for extension of time is being filed in the pending prior 
application. 

[ ] A copy of the conditional petition filed in the prior application is attached. 
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20. Further Inventorship Statement Where Benefit of Prior Application(s) Claimed 
(complete applicable item (a), (b) and/or (c) below) 

(a) [ ] This application discloses and claims only subject matter disclosed in the 
prior application whose particulars are set out above and the inventor(s) 
in this application are 

[ ] the same. 

[ ] less than those named in the prior application. It is requested that 
the following inventor(s) identified for the prior application be 
deleted: 



(type name(s) of inventor(s) to be deleted) 

This application discloses and claims additional disclosure by amendment 
and a new declaration or oath is being filed. With respect to the prior 
application, the inventor(s) in this application are 

[ ] the same. 

[ ] the following additional inventor(s) have been added: 



(type name(s) of inventor(s) to be added) 

(c) The inventorship for all the claims in this application are 
[X] the same. 

[ ] not the same. An explanation, including the ownership of the various 
claims at the time the last claimed invention was made 

[ ] is submitted. 

[ ] will be submitted. 
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21 . Abandonment of Prior Application (if applicable) 

[ ] Please abandon the prior application at a time while the prior application is 

pending, or when the petition for extension of time or to revive in that application 
is granted, and when this application is granted a filing date, so as to make this 
application copending with said prior application. 

NOTE: According to the Notice of May 13, 1983 (103, TMOG 6-7), the filing of a continuation or 

continuation-in-part application is a proper response with respect to a petition for 
extension of time or a petition to revive and should include the express abandonment of 
the prior application conditioned upon the granting of the petition and the granting of a 
filing date to the continuing application. 



22. Petition for Suspension of Prosecution for the Time Necessary to File an Amendment 

WARNING: 

"The claims of a new application may be finally rejected in the first Office action in those situations where 
(1) the new application is a continuing application of, or a substitute for, an earlier application, and (2) all 
the claims of the new application (a) are drawn to the same invention claimed in the earlier application, 
and (b) would have been properly finally rejected on the grounds of art of record in the next Office action if 
they had been entered in the earlier application." M.P.E.P., § 706.07(b) , 6th ed., rev. 2. 

NOTE: Where it is possible that the claims on file will give rise to a first action final for this 

continuation application and for some reason an amendment cannot be filed promptly 
(e.g., experimental data is being gathered) it may be desirable to file a petition for 
suspension of prosecution for the time necessary. 

(check the next item, if applicable) 

[ ] There is provided herewith a Petition To Suspend Prosecution for the Time 
Necessary to File An Amendment (New Application Filed Concurrently) 



23. Small Entity (37 C.F.R. § 128(a) ) 

[ ] Applicant has established small entity status by the filing of a statement in parent 
application / on . 

[ ] A copy of the statement previously filed is included. 

WARNING: 

See 37 C.F.R. § 1.28(a) . 
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WARNING: 

"Small entity status must not be established when the person or persons signing the ... statement can 
unequivocally make the required self-certification." M.P.E.P., § 509.03, 6th ed., rev. 2, July 1996 
(emphasis added). 

24. NOTIFICATION IN PARENT APPLICATION OF THIS FILING 
[ ] A notification of the filing of this 

(check one of the following) 

[ ] continuation 

[ ] continuation-in-part 

[ ] divisional 

is being filed in the parent application, from which this application claims priority 
under 35 U.S.C. § 120 . 



SHERMAN & SHERMAN REF. NO.: SAM1.0064 



ADDED PAGES FOR APPLICATION TRANSMITTAL WHERE 
BENEFIT OF PRIOR U.S. APPLICATION(S) CLAIMED 



Page 8/8 



Added page 



NOTE: The Notice of August 1, 1986, 1069 O.G. 40, states: 



"NEW APPLICATIONS-Payment of Processing and Retention Fees- An application, 
which has become abandoned pursuant to 37 C.F.R. § 1 .53(d) for failure to pay the filing 
fee, will be disposed of unless the processing and retention fee set forth in § 1.21(1) is 
paid within the 1-year period referred to in § 1.53(d) . Moreover, the processing and 
retention fee must be timely paid in order to obtain certified copies of the application (e.g., 
for convention priority purposes) or to establish a later filed application the filing date 
benefit of an earlier copending application under 37 USC 120 and 37 C.F.R. § 1.78(a)(3) . 
Therefore, an application which has become abandoned for the reasons set forth above 
should be immediately reviewed in order to timely determine the advisability of submitting 
a processing and retention fee payment. 

"Direct any questions reagarding this helpful hint to: 
"A! Lawrence Smith 
"Director, Group 350 
"(703) 557-3414 
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Home Network Device Information Architecture 

By 

Dongyan Wang 
And 

Richard Humpleman 

Notice of Inclusion of Copyrighted Material 

A portion of the disclosure of this patent document contains material which is 
subject to copyright protection. The copyright owner has no objection to the facsimile 
reproduction by anyone of the patent disclosure, as it appears in the Patent and 
Trademark Office patent files or records, but otherwise reserves all copyright rights 
5 whatsoever. 

Cross-References to Related Applications 

Applicants claim the benefit of U.S. Provisional Application No. 60/146,101 
entitled "Network Architecture," filed on July, 27, 1999, and U.S. Provisional Application 
10 No. 60/149,515 entitled "External Web Server Included in Home Network Top-Level 
User Interface Description," filed on August 17, 1999, which applications are 
incorporated herein by reference. 

Field of the Invention 

15 The present invention relates to the field of networks, and more particularly, to 

home networks having multi-media devices connected thereto. 

Background of the Invention 

A network generally includes a communication link and various devices with 
20 communication capability connected to the communication link. The devices include 
computers, peripheral devices, routers, storage devices, and appliances with 
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processors and communication interfaces. An example of a network is a home network 
for a household in which various devices are interconnected. A usual household can 
contain several devices including personal computers and home devices that are 
typically found in the home. As such the term "device" typically includes logical devices 

5 or other units having functionality and an ability to exchange data, and can include not 
only all home devices but also general purpose computers. Home devices include such 
electronic devices as security systems, theater equipment, TVS, VCRs, stereo 
equipment, and direct broadcast satellite services or (DBSS), also known as digital 
satellite services (DSS), sprinkler systems, lighting systems, micro waves, dish washer, 

10 ovens/stoves, washers/dryers, and a processing system in an automobile. 

In general, home devices are used to perform tasks that enhance a homeowners 
life style and standard of living. For example, a dishwasher performs the task of 
washing dirty dishes and relieves the homeowner of having to wash the dishes by hand. 
15 A VCR can record a TV program to allow a homeowner to watch a particular program at 
a later time. Security systems protect the homeowners valuables and can reduce the 
homeowners fear of unwanted entry. 

Home devices, such as home theater equipment, are often controlled using a 
20 single common control unit, namely a remote control device. This single common 
control unit allows a homeowner to control and command several different home 
devices using a single interface. Thus, may manufacturers have developed control units 
for controlling and commanding their home devices from a single interface. 

25 One drawback associated with using the remote control unit to command and 

control home devices is that it provides static and command logic for controlling and 
commanding each home device. Therefore, a particular remote control unit can only 
control and command those home devices for which it includes the necessary control 
and command logic. For example, if a remote control unit comprises logic for 
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controlling a television (TV), a video cassette recorder (VCR), and a digital video device 
(DVD), but not a compact disk (CD) unit, the remote control unit can not be used to 
command and control the CD unit. In addition, as new home devices are developed, the 
remote control unit will not be able to control and command the new home devices that 
5 require control and command logic that was not known at the time the remote control 
unit was developed. 

Further, typically a remote control unit can only be used to command and control 
those home devices that are within the signal range of the remote control unit. 

10 Therefore, a user cannot use the remote control unit from a single location in the house 
to control and command home devices that are interconnected, but located in separate 
areas of the home. For example, a VCR that is located upstairs in a bedroom may be 
connected to a TV that is downstairs in the family room. If a user wishes to play a tape 
contained in the VCR located upstairs in the bedroom, on the TV located downstairs in 

15 the family room, the user cannot control and command both the TV and the VCR from a 
single location. 

Another drawback associated with using remote control units is that known 
remote control units cannot control a plurality of diverse devices, and more particularly, 
20 cannot control a plurality of devices having different capabilities to communicate with 
each other in order to accomplish tasks or provide a service. Further, conventional 
network systems do not provide a mechanism for software applications in different 
network devices to automatically communicate with one another in order to accomplish 
tasks without direct user command. 

25 

To alleviate the above problems, some network models provide a 
central/singular user interface (Ul) in one device including static device information for 
networked devices for user control of network devices. However, in such networks a 
change to device information (e.g., ICON) in a device requires a change to, and 
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rebuilding of, the top level page. Further, if the device displaying the central user 
interface becomes unavailable, user control of the network is curtailed. Another 
problem with the central/singular page is that every Ul device must display the same 
page, and a scope is not provided for each manufacturer to generate its own Ul look 

5 and feel nor alter the technology used in the Ul device. The content of an 

icon/information representing a device cannot be changed, and a Ul device cannot 
display a more prominent look to a device icon such as the icon for the Ul device itself. 
Nor can a Ul builder tool obtain e-business icons from an external Web Portal. Such a 
model cannot be standardized for industry use because a central/single Ul device 

10 controls the U I. 

There is, therefore, a need for a method and a system which provides dynamic 
control and command devices in a home network. There is also a need for such a 
method and system to provide the ability to control a plurality of diverse devices having 
15 different capabilities via different dynamic user interfaces. 

Brief Summary of the Invention 

The present invention satisfies these needs. In one embodiment, the present 
invention provides a method and system for providing a user interface for controlling 

20 devices that are currently connected to a network, such that at least one of said devices 
performs steps including: (a) obtaining information from one or more of the devices 
currently connected to the network, said information including device information; and 
(b) generating a user interface description based at least on the obtained information, 
the user interface description including a reference associated with the device 

25 information of each of said devices currently connected to the network, such that the 
reference includes at least one link to information contained in said devices currently 
connected to the network. As such, a user interface can be displayed using the 
references in the user interface description, for controlling said devices currently 
connected to the network. 
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In one version, a top-level home network (HN) directory page can be described 
entirely in the 'abstract 1 to allow devices freedom to control device icon information 
called by reference (not directly). This allows the devices to change icon content and 
5 content technology without incurring the overhead of command and control back to a 
central device to make the change. Further, there is no need for a central device, 
because the top-level HN directory always uses the same abstract references and any 
device can use the references to provide user access to all devices. 



10 Brief Description of the Drawings 

These and other features, aspects and advantages of the present invention will 
become better understood with regard to the following description, appended claims 
and accompanying drawings where: 

15 FIG. 1 shows an example block diagram of the architecture of an embodiment of 

a network according to the present invention; 

FIG. 2 shows an example block diagram of the architecture another 
embodiment of a network according to the present invention; 

20 
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FIG. 3 illustrates an example of a layered interface model that can be used for 
communicating between home devices in accordance with the present invention; 

FIG. 4a shows an example architecture diagram of a DVCR server device 
5 replaying video to a DTV client device capable of displaying a user interface, in a 
network according to the present invention; 

FIG. 4b shows another example architecture diagram of a server device 
communicating with a client device capable of displaying a user interface, in a network 
10 according to the present invention; 

FIGS. 5-6 illustrate example top-level GUIs representing the functions of 
networked devices to a user; 

15 FIG. 7 shows an example block diagram architecture of a home network 

constructed in accordance with another embodiment of the present invention; 

FIG. 8 shows an example process according to the present invention for 
communication between a 1394 network and a non-1394 network for IP address 
20 configuration; 

FIGS. 9a-c show example functional block diagrams of connections to data and 
control bits of an embodiment of a discovery system architecture in a network according 
to another aspect of the present invention; 

25 

FIG. 10 shows an example flow diagram for discovery and configuration agents 
in the home network in connection with the functional block diagrams in FIGS. 9a-c; 

FIG. 11 shows an example flow diagram for user interface agent in the home 
network in connection with the functional block diagrams in FIGS. 9a-c; and 
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Appendices 1-4, illustrative examples for: (1) Top-Level Page description 250 
(Appendix 1); (2) Background.htm (Appendix 2); (3) lcon.htm (Appendix 4); and (4) 
Name. htm (Appendix4). 

5 To facilitate understanding, identical reference numerals have been used, where 

possible, to designate identical elements that are common throughout the figures. 

Detailed Description of the Invention 

Network Overview 

10 Referring to FIG. 1 , in an embodiment of the present invention, a network 10 

comprises multiple devices 1 1 including at least one client device 12 and at least one 
server device 14 interconnected via a communication link 16. The communication link 
16 can include a 1394 serial bus providing a physical layer (medium) for sending and 
receiving data between the various connected home devices. The 1394 serial bus 

15 supports both time-multiplexed audio/video (AA/) streams and standard IP (Internet 
Protocol) communications (e.g., IETF RFC 2734). In certain embodiments, a home 
network uses an IP network layer as the communication layer for the home network. 
However, other communication protocols could be used to provide communication for 
the home network. For example, the invention may be implemented using Function 

20 Control Protocol (FCP) as defined by IEC 61883, or any other appropriate protocol. 
Thus, a network may generally include two or more devices interconnected by a 
physical layer exchange or transfer of data in accordance with a predefined 
communication protocol. 

25 Each client device 12 may communicate with one or more server devices 14 in 

the network 10. Further, each server device 14 may communicate with one or more 
other server devices 14, and one or more client devices 12, in the network 10. Each 
client device 12 can include a user communication interface including input devices 
such as a mouse and keyboard for receiving user input, and a display for providing a 
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control user interface for a user to interact with the networked devices. The user 
interface can include a graphical user interface (GUI) 18 for providing information to the 
user. Each server device 14 includes hardware as a resource in the network for 
providing services to the user, and can further include a server or service control 
5 program 20 for controlling the server hardware. 

Each server device 14 provides a service for the user, except control user 
interface, and each client device 12 provides a service including control user interface 
for user interaction with the network 10. As such, only client devices 12 interact directly 
10 with users, and server devices 14 interact only with client devices 12 and other server 
devices 14. Example services can include MPEG sourcing/sinking and display 
services. 

In an exemplary embodiment of the present invention, a browser based network 
15 (e.g., a home network) uses Internet technology to control and command devices 
including client devices and server devices that are connected to a network. Each 
device includes device information such as interface data (e.g. HTML, XML, JAVA, 
JAVASCRIPT, GIF, JPEG, graphics files, or any other format useful for the intended 
purpose) that provides an interface for commanding and controlling of the device over 
20 the network. In certain embodiments, each device includes device information such as 
one or more Hypertext markup Language (HTML) pages that provide for the 
commanding and controlling of that device. Using the browser technology, the network 
employs Internet standards to render the HTML pages in order to provide users with a 
plurality of graphical user interface (GUIs) for commanding and controlling each device. 
25 In one example, the network is configured as an Intranet. 

In one embodiment, a client device comprises a device providing control 
interface service to a human operator, including a graphical display hardware for down 
communication and a mouse or other point-and-click device for up (or return) 
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communication. A server device comprises a module supplying a service, which can be 
any service other than a control interface provided by a client device. As such, the 
server/client device relationship is a control relationship, wherein the server device 
provides a service but a client device can use the data, as a DTV displays video data, 
5 but need not manipulate or alter the data. It is thus consistent with this definition to 
observe that, frequently, a server may be a source of information and a client (a 
browser, for example) may be a consumer of information. 

Examples of specific functions which can be implemented by server devices 
10 include: return of information (data); performance of a function (e.g., mechanical 
function) and return of status; return of a data steam and status; reception of a data 
stream and return of status; or saving of a state for subsequent action. Examples of 
server devices include MPEG source, sink and display servers. While a server device 
typically includes a custom, built-in, control program to implement control of its own 
15 hardware, a client functions to interface with the server device. However, server device 
as used herein does not imply that a web server and a protocol stack must be used. 

FIG. 2 shows a block diagram of an embodiment of a network 100 according to 
an aspect of the present invention. A 1394 serial bus 1 14, described above, 

20 electronically connects multiple devices 1 1 including server devices 14 (e.g., DVD 108, 
DVCR 110), client devices 12 (e.g., DTV 102, 103), Bridge 116, DVCR120, PC 105, 
cable/modem access 107, and DBS access 109, on the network 100. FIG. 3 illustrates 
an example of a layered interface model that can be used for communicating between 
the devices 1 1 in accordance with the present invention. In this example, a device 

25 (server) 150 communicates with a client device 166 using one or more of the network 
communication layers 152-164. In one example, an application in the device 150 
communicates with an application in the device 166 via the network layer 160. The 
details of lower layers 162 and 164 are not seen by the applications, whereby use of 
e.g. either 1394 or Ethernet does not make a difference to said applications in the 
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devices 150, 166. Further not all the upper layers of the 7-layer model are used all the 
time (e.g., in the Web model (TCP/IP model) session layer 156 and presentation layer 
154 are not used). As such, in one version, by employing the Internet Protocol 
standard for the network layer 160, the devices can communicate with each other 
5 without having to know specific details about the other communication layers (i.e. 
application 152, presentation 154, session 156, transport 158, data link 162 and 
physical 164). Thus, by employing the Internet Protocol standard for the network layer 
160, the network can use a combination of different communication layers in 
communicating between different devices. 

10 

A single physical package can include several devices which are logically 
networked via a network layer for example as shown in FIG. 3 not necessarily via a 
physical network (e.g., such devices can include a VCR and a TV in a single housing). 
Where a logical device accesses a GUI to enable a user to control a device, the device 
15 and the logical device can be included in the same physical package. In such an 
embodiment, the physical device fetches a GUI from itself. However, in other 
embodiments the network interconnects separate physical devices, wherein for 
example, a first device fetches a GUI from a second device, to permit user interaction 
with the GUI to control the second device. 

20 

In a presently preferred embodiment, a 1394 serial bus is used as the physical 
layer 164 for the data communications on the network 100. Because of its enhanced 
bandwidth capabilities (e.g., enhanced and guaranteed bandwidth and isochronous 
stream capability), the 1394 serial bus can provide a single medium for all data 
25 communications on the network 1 00 (i.e. audio/video streams and command/control). 

Further, the 1394 serial bus provides automatic configuration reset such that 
when a device is plugged in/removed all the 1394 interfaces reset, the 1394 bus 
reconfigures and every device knows the presence of every other device (including a 
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newly added one or without the one just removed). Also, the 1394 interface supports a 
data space for configuration information that is addressable from any device allowing 
other devices to write/read information and make modifications e.g. to permit the 
operation of the network layer protocol. However, it is possible to achieve these results 
5 with different software and standards. As such, the network 100 is not restricted to 
using a 1394 serial bus, and, in alternative embodiments of the present invention, other 
bus types, such a Ethernet, ATM, wireless, etc., can be used as the physical layer if 
they meet the particular throughput requirements of an individual network (e.g., a home 
network) . Further, a modified version of e.g. wireless-Ethernet can include the 
10 essential features of 1 394. 

As depicted in FIG. 2, the network 100 includes several devices connected to 
the 1394 serial bus 114. In this example, the devices include a DBSS 104 for receiving 
transmission signal from a satellite 122 for subsequent display. Associated with the 
15 DBSS is a network interface unit ("NIU") which, among other things, provides an 
interface between the DBSS satellite transmission and the 1394 serial bus 114. 

A digital video device (DVD) 108 is also connected to the exemplary network 
100. The DVD 108 can be used to display digitally encoded videos on a television. Also 

20 connected to the exemplary network 100 is a digital video cassette recorder (DVCR) 
110, i.e., a digital TV 102. In this example, the DTV 102 provides a human interface for 
the network 100 by employing browser technology to allow users to control and 
command for devices over the home network 100. A second DTV 103 provides 
another human interface for the network 1 00 by employing browser technology to allow 

25 users to control and command for devices over the home network 100. The DTVs 102 
and 103 can provide human interfaces for the network 100 as each DTV comprises a 
screen for displaying HTML pages. However other devices having display capability can 
be used to provide human interfaces. Thus, in certain embodiments of the invention, a 
device such as the personal computer 105 (PC) is used to provide a human interface 



12 



for a respective home network, as a PC 105 typically embodies a screen display unit. 



The 1394 serial bus 114 is depicted as using the HTTP/IP interface protocol, and 
preferably HTTP/TCP/IP, wherein IP provides packet format (a one-way write only 

5 model), TCP provides an error free version of IP (e.g., ensures packets arrive and in 
correct order), and HTTP provides 2-way connection (packet to server will expect a 
response -a 'read' model). Certain devices can require other protocol interface types 
(e.g., UPD/IP, FTP/IP, TELNET/IP, SNMP/IP, DNS/IP, SMTP/IP). In certain 
embodiments of the invention, a proxy 1 16 can be used to interface two networks using 

10 dissimilar interface protocols on their respective mediums which, when connected, 
comprise the network 100. The proxy 1 16 (e.g. Web proxy) can include Home 
Automation type protocols such as the HTML/HTTP/TCP/IP proxy for X10, Lonworks, 
CEBus (on their respective physical technologies), or non-IP protocols on 1394 (e.g., 
AVC/FCP/1394). 

15 

In certain embodiments, the two network mediums are of the same type. For 
example, as depicted in FIG. 2, the 1394 serial bus 114 using the HTTP/IP interface 
protocol is connected by a proxy 1 16 to the Home Automation neutral 118 (e.g., X10). 
By using the proxy 116 as HTML/HTTP/CTP/IP/1394 proxy for VCR- 

20 Commands/AVC/FCP/1 394, to interface between HTML/HTTP/TCP/IP and X1 0 
protocols, DVCR 120 is also accessible on the network 100. In certain other 
embodiments, a network can comprise two network mediums of dissimilar types, e.g., a 
1394 Serial bus and Ethernet. Therefore, in certain embodiments of the invention, a 
proxy is used to interface two dissimilar medium types to from a single network. A 

25 discovery process, described further below, can be used for the discovery of devices 
that are powered on and connected to the network 100. Also, the same 1394 bus can 
be used without need for a bridge box. 

As depicted in FIG. 2, devices 11 including DTV 102, DTV 103, PC 105, DVCR 
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110, DVD 108, DSS-NIU 104 and DVCR 120 represent devices that are currently 
connected to the network 100 comprising a 1394 network. A client-server relationship 
exists among the attached devices, with the DTV 102 , DTV 103 and PC 105 typically 
behaving as clients and devices DVCR 110, DVD 108, DSS-NIU 104 and DVCR 120 
5 behaving as servers. 

A typical1394 network comprises interconnected devices such as a collection of 
appliances including server devices offering one or more services to be controlled (e.g., 
DVCR 100 as an MPEG video recording and replay service), and client device offering 

10 a user interface (Ul) service (e.g., DTV 102) for controlling the server devices. Some 
appliances (e.g., DTV 103) can have both services (e.g., MPEG decode and display 
capability) to be controlled, and a Ul controller capability. According to an aspect of the 
present invention, methods and systems including protocols, document description, 
image compression and scripting language standards from technologies utilized in the 

15 World Wide Web standard (Web model) are used to implement t a 1 394WEB user-to- 
device control model in the network 100. The Web model is a client/server model. The 
controlled server device (service) comprises a Web server and the controller client 
device (i.e., a device capable of displaying a Ul) comprises a Web client including a 
GUI presentation engine, described further below, such as a Web browser (e.g., 

20 Explorer ™, Netscape™, etc.) 

User Device Control 

FIG. 4a shows a server device such as the DVCR 1 10 replaying MPEG video to 
a client device such as the DTV 102 in a network 100 according to the present 
25 invention, wherein the DTV 102 can display a user interface. The DVCR 1 1 0 includes 
Web server hardware and software and the DTV 102 includes Web browser software. 
A user can utilize the DTV 102 to request that the DTV 102 display a user interface 
based on the device information 202 contained in the DVCR 1 10 or based on the 
device information 204 contained in the DTV 102. For example, the user can utilize a 
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browser 200 in the DTV 102 to display an HTML control page GUI 202 contained in the 
DVCR 1 10 or an HTML control page GUI 204 contained in the DTV 102. Each page 
202, 204 includes graphical user interface description information in HTML, wherein the 
browser 200 reads that information to generate a graphical user interface. Each page 
5 202, 204 represents the Control Interface of the Applications 206, 212, respectively. 
Each page 202, 204 can include a hierarchy of pages to represent a corresponding 
application control interface. 

Each GUI 202 and/or 204 includes active control icons and/or buttons for the 
10 user to select and control devices currently connected to the network 100. If, for 

example, the user selects a PLAY button in the GUI 202 of the DVCR 110 displayed by 
the browser 200 on the DTV 102, a hyperlink message is returned to the DVCR 110 
Web server and directed to an application software 206 (e.g., MPEG Record/Replay 
Service Application Software) in the DVCR 1 10 for operating a DVCR hardware 208. In 
15 one example, an MPEG video stream source 208 in the DVCR 110 transmits an MPEG 
video stream to an MPEG vide decode and display system 210 in the DTV 102 for 
display under the control of application control software 212 in the DTV 102. The 
application software 206 in the DVCR 110 also sends information back to the 
application software 212 in the DTV 102, including e.g. an acknolwdgement if the 
20 operation is successful, or an altered or different control GUI 202 to the DTV 102 
indicating status to the user. There can be further communication between the 
application softwares 206 and 212 e.g. for setting up a 1394 isochronous video stream 
connection for video stream service. 

25 FIG. 4b shows another example architecture diagram of a server device 

communicating with a client device capable of displaying a user interface, in a network 
100. The server device such as DVCR 110 replays MPEG video to the client device 
such as the DTV 102 in the network 100, wherein the DTV 102 can display a user 
interface. 
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Communication Protocol 

In an embodiment of the invention, the communication protocol between devices 
in the network 100 is based on the Hypertext Transfer Protocol (HTTP 1.1), an 
application-level protocol for distributed, collaborative, hypermedia information systems. 
5 HTTP is a generic, stateless, object-oriented protocol that can be use for many tasks. A 
feature of HTTP is the typing and negotiation of data representation, allowing devices to 
be built independently of the data being transferred over the network 100 to which the 
devices are connected. 

10 GUI Description Language 

The description document language for defining various GUIs 202, 204 can be 
e.g. HTML, version 4.0, the publishing language of the World Wide Web. HTML 
supports text, multimedia, and hyperlink features, scripting languages and style sheets. 
HTML 4.0 is an SGML application conforming to International Standard ISO 8879 - 

15 Standard Generalized Markup Language. 

Image Compression Formats 

To display images, three still image graphics compression formats specified by 
the HTML specification are utilized in the 1394WEB network 100 for ICON, LOGO and 
20 other graphics. The still image graphics compression formats are: Graphics Interchange 
Format (GIF89s) , Progressive Joint Photograhic Experts Group (JPEG) and Portable 
Network Graphics (PNG). Table 1 shows the differences in capabilities between the 
three different still image graphics compression formats. 
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Table 1: Still Image Compression Formats 
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PNG 


Progressive 
JPEG 


GIF89a 


Color Depth 


48 bit 


24 bit 


8 bit 


Colors Supported 




16.7 million 


256 


Formats Supported 


Raster, Vector 


Raster 


Raster 


Compression 

Vl aim A 

ocnerne 


LZ77 derivative 


JPEG 


LZW 


I ransparency 


Ppr Pixel for Grayscale 
& RGB, 

Per Color for Indexed, 
256 levels 


No 


Single Color, 

2 levels 
(Binary) 


Progressive Display 


Yes 


Yes 


Vac 

Yes 


Scalable 


No 


IMO 


INO 


Animation 




No 


Yes 


Lossless 
Compression 


100% 






Truecolor 


48 bits 






Grayscale 


16 bits 






Indexed-color 


yes 






Gamma Correction 
(light intensity) 


Yes 






Chromaticity 
Correction 


Both 






Searchable Meta- 
Data 


Yes 






Extensibility 


Yes, chunk encoded 







25 Scripting Language 

Further, the Web scripting language, ECMA-Script-262, is utilized to provide a 
means for visually enhancing the GUI Web pages 202 as part of a Web-based client- 
server architecture. The scripting language is a programming language for 
manipulating, customizing, and automating the facilities/services of the devices. The 

30 user interface 200 provides basic user interaction functions, and the scripting language 
is utilized to expose that functionality to program control. The existing system provides 
the host environment of objects and facilities completing the capabilities of the scripting 
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language. The web browser 200 provides the ECMA-Script host environment for client- 
side computation including, for example, objects that represent windows, menus, pop- 
ups, dialog boxes, text areas, anchors, frames, history, cookies, and input/output. 

5 The web browser 200 provides the host environment for the EXMA-Script-262, 

and the host environment supports attaching scripting code to events such as change 
of focus, page and image loading, unloading, error and abort, selection, form 
submission, and mouse actions. Scripting code is included within the HTML pages 202 
and 204 and the displayed page is the browser 200 includes a combination of user 

10 interface elements, and fixed and computed text and images. The scripting code 
responds to user interaction without need for a main program. 

Client Device Specification 

In one example, the specification for a 1394WEB client browser 200 includes 

15 HTTP 1.1 specification, wherein section '8.1 .2.1 Negotiation' of the HTTP1.1 

specification regarding connection persistence is modified such that an HTTP1.1 client 
device such as e.g. the DTV102 expects a connection to server device such as e.g. the 
DVCR 110 via the 1394 to remain open, because the persistent connection in 
1394WEB user control allows full status reporting from the server device (DVCR 110) 

20 while the GUI 202 and/or 204 remains visible in the browser 200 of the client device 
(DTV 102). The HTTP connection remains open (HTTP spec RFC 2068) wherein a 
client that supports persistent connections may "pipeline" its requests (i.e., send 
multiple requests without waiting for each response). A server must send its responses 
to those requests in the same order that the requests were received. This allows the 

25 web browser 200 to pipeline requests to the DVCR 1 1 0 which the DVCR 1 1 0 can then 
satisfy later with e.g. status responses such as Now Playing, Now Recording, Rewind 
Finished, Tape Broken, Etc. Other example implementations include e.g. the control 
page from the DVCR 110 can contain a request to loop on the DVCR 100 request of 
GUI description 202. 
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The GUI presentation engine 200 is utilized in the client device such as the DTV 
102 to interpret GUI descriptions 202, 204 written in the HTML4.0 document description 
language and the associated specifications (below), and to create the graphical form for 
display to the user. The GUI presentation engine 200 includes the following e.g. 

5 attributes: (1) window (GUI) minimum default size of e.g., H0x640 pixels (480x640 
where 480 vertical, 640 horizontal). This default size is to insure the intended 
appearance in the GUIs 202, 204 is transferred to the user in the browser 200. The 
transferred GUIs 202, 204 are displayed in a window 480x640 pixels or magnified larger 
with the same aspect ratio unless otherwise directed by the user; (2) still image 

10 compression formats: e.g., GIF89a, JPEG, and PNG; (3) style sheet formats and fonts: 
e.g., CSS1 and CSS2; (4) fonts such as the following e.g. built-in fonts are required for 
the client device to free simple server appliances from having to support such fonts. 
Minimum one font from each generic Latin family can be selected: e.g., Times New 
Roman, from 'serif family; Helvetica, from 'sans-serif family; Zapf-Chancery, from 

15 'cursive 1 family; Western from 'fantasy' family; and Courier from 'monospace' family. 
Other fonts can also be utilized; and (5) scripting language e.g., ECMA-262. Examples 
of the GUI presentation engine 200 include Web browsers such as Explorer ™ and 
Netscape™ configured/customized as desired. 

20 Server Device Specification 

One or more of the server devices (e.g. a 1394WEB network, controlled 
appliance Web server such as the DVCR 110), include the following six enumerated 
components: 

25 (1) HTTP 1.1 web server protocol, with section '8.1.2.1 Negotiation' of the 

HTTP1.1 specification regarding connection modified such that an HTTP 1.1 server 
device (e.g. DVCR 110) assumes that a HTTP1.1 client device (e.g., DTV 102) intends 
to maintain a persistent connection with the server device. The persistent connection in 
the 1394WEB network 100 allows full status reporting from e.g. the server device 
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DVCR 110 to the client device DTV 102 while the GUI 202 of the DVCR 110 remains 
visible in the browser 200 of the DTV 102. Further, a method using HTTP conditional 
GET to obtain the latest status of server devices can be used. Whenever the user 
returns to the home network directory or causes it to be refreshed, the browser 200 

5 redisplays the page in its entirety. This is necessary because the HTML that underlies 
the home network directory may have been regenerated if a device has been added to 
or removed from the network 100. It is also possible for device icons to be updated to 
reflect changes in their device's operating state. As such, browsers implemented by 
EIA-775.1 devices utilize HTTP "conditional get" requests to determine whether or not 

10 fresh copies of web pages or graphics should be retrieved from the server. 

(2) Device home page GUI descriptions 202, 204 written e.g. in HTML4.0, 
include file e.g. icon. htm, name.htm, logo.htm, index.htm, gif files, etc.. The file 
index.htm is referenced by HTML links included in device icon.htm and name.htm 

15 HTML files, wherein index.htm can be optionally named e.g. "INDEX.HTML" or 

"INDEX.HTM". File named INDEX.HTM is not required to be a standard name because 
the ICON.HTM and NAME.HTM are made with hyperlinks to the 'INDEX.HTM', 
therefore the name is arbitrary. ICON.HTM and LOGO.HTM reference the actual 
graphics files in the same device e.g. LOGO.GIF and ICON.GIF. The descriptions 202, 

20 204 are accessible by the devices (e.g., HTTP devices) in the network 100. To 

guarantee a desired appearance, the control GUI design can be for a default GUI size 
of e.g. 480x640 pixels. For example, a transferred GUI 202 can be displayed in a 
window of 480x640 pixels in the browser 200 or magnified larger with the same aspect 
ratio unless otherwise directed by the user. 

25 

(3) At least two device ICON files are provided to represent the device in 
a top-level network page 220 (FIGS. 5-6) in the browser 200 showing information about 
the devices connected to the network. An ICON can comprise a graphic file type (e.g. 
GIF, JPG or PNG) and named ICON.HTM. In one example, ICON.HTM(DVCR) 
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references the INDEX.HTM file in the HTML page 202 and ICON.HTM(DTV) references 
the INDEX.HTM file in the HTML page 204. The top-level link for the control pages 
(e.g., INDEX.HTM) of the device can be ICON. HTM. The browser 200 places the icons 
and links therein) of a plurality of devices in the network 100 in the top-level HN 
5 directory page 220 for service discovery by the user. Then user clicks the ICON 
displayed in the page 220 and the device page (e.g. INDEX.HTM in page 202) is 
fetched. The default displayed HN directory is the top-level discovery page. 

A number of additional and different graphic icons can also be utilized, for 
10 example, to represent device status, user configured preference or manufacturers 
formats which may be substituted for the icon graphic. In a discovery process 
described further below, ICONs from the devices connected to the network 100 are 
collected together and displayed in the top level network devices page 220 for selection 
by a user. An example device ICON specification comprises: File name ICON. HTM 
15 accessible by the HTTP server (files names are in a directory, file space, accessible by 
the web server so that they can be retrieved and forwarded over the network to the 
browser); Graphic file type such as GIF, JPG or PNG; and Icon graphic with a 
maximum size of 70(V)x1 30(H) pixels. 

20 (4) At least two device LOGO files are provided to represent the device in 

the top-level network devices page. LOGO can comprise a graphic file type (e.g., GIF, 
JPG or PNG) and named LOGO. HTM. In one example, LOGO.HTM(DVCR) 
references the INDEX.HTM in the HTML page 202 and LOGO. HTM (DTV) references 
the INDEX.HTM in the HTML page 204. In one version, the top-level link for the control 

25 pages (e.g., INDEX.HTM) of the device can be LOGO. HTM. All device logos are 
placed in the top-level HN directory page 220 for service discovery by the user. Then 
user clicks the LOGO displayed in the page 220 and the device page (e.g. 202) is 
fetched. A number of additional and different graphics for manufacturer services can be 
substituted for the logo graphic format . According to the discovery process, LOGOs 
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from devices connected to the network 100 are collected together and displayed in the 
top level network devices page 220 for selection by a user. An example device LOGO 
specification comprises: File name LOGO. HTM accessible by the HTTP server; Graphic 
file type such as GIF, JPG or PNG; and logo graphic maximum size of about 
5 70(V)x1 30(H) pixels. 

(5) At least one device NAME is provided to represent the device in the 
top-level network devices page. NAME comprises TEXT in an HTML file NAME. HTM. 
This text can also reference control pages (e.g., 202). This is a top-level link in the 

10 discovery page to the control interface of the device. The text provides a way to 
distinguish identical devices whereby for e.g. two identical DTV's can be distinguished 
by adding NAME text 'Bedroom TV 1 and 'Family Room TV'. The text can comprise a few 
words to clearly represent the device type e.g. DVCR or DTV. According to the 
discovery process, NAMEs from devices connected to the network are accessed along 

15 with corresponding ICONs/LOGOs and displayed in the top level network devices page 
220 under the ICON/LOGO. An example NAME specification comprises: File name 
NAME. HTM accessible by the HTTP server; Text unspecified, such as, with Font size 
10, two lines of text can be displayed under the corresponding ICON/LOGO. Therefore, 
for example the space size for the NAME. HTM text can be 20 vertical by 130 horizontal 

20 to match the ICON/LOGO (70 vertical x 130 horizontal). As shown by example in FIGS. 
5-6, the format of the top-level Ul 220 can comprise a matrix of icons representing the 
functions of the networked devices to the user. The name representing the device (from 
name.htm) is placed under the icon (from icon. htm) from the same device. Logo (from 
logo.htm) may be placed e.g. in any vacant icon position. As the Top-level description 

25 250 (described further below in conjunction with FIGS. 9a-c) is generated independently 
by Ul capable devices, the exact design need not be prearranged. The icon, logo and 
name maximum sizes can be prearranges to facilitate design of the GUI matrix. 
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(6) A device information summary home page description document 
written in HTML4.0 can be provided, named e.g. "info.html" or "info.html", and made 
accessible by the HTTP server for the discovery process. A link can be provided to 
INFO.HTML information via control pages e.g. 202, 204. The device information 
5 summary homepage provides the user a device summary instead of the detailed control 
interface as shown in the device homepage. Table 2 shows device attributes text that 
are included and others that can be included. This table can be extended to included 
other attributes. 

10 Table 2 - Device information summary 
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Name 




Device Name 


Device name (user configurable) 


Device Location 


Device location in home (user configurable) 


Device Icon 


Current Device ICON name 


Device Type 


Device type or category (VCR, DSS, TV, etc.) 


Device Mode! 


Device model 


Manufacturer Name 


Name of device manufacturer 


Manufacturer Logo 


Manufacturer Logo image name 


Manufacturer URL 


Device manufacturer's URL 


Stream Source Name 
Default 


Service: Default source device name for this Device's 
destination service 


Stream Destination 
Name Default 


Service: Default destination device name for this Device's 
source service 


Stream Source 
Attributes 


Type of service device can deliver (attributes and 
capability) 


Stream Destination 
Attributes 


Type of service device can receive (attributes and 
capability) 



30 

Table 2 includes device summary information such as Manufacturer Name, 
Manufacturer Logo image name, and can further include a Manufacturer URL for help if 
there is an available Internet connection to the manufacturers Web site. Table 2 can 
further include a user configurable Device Name and Device Location in the home. 
35 There can be several variations of the Device Icon representing different states of the 
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device. The Device Icon attribute field includes the name of the current icon. Therefore, 
the device summary information page can provide immediate device state information 
to the user by displaying the icon representative of current state. 

5 Each device can include one or more services, e.g. video Stream Source or 

video Stream Destination. Each source capability has a complementing Default 
Destination capability and each destination capability has a complementing Default 
Source capability. This Stream Default Name entry can be used e.g. to automatically 
default the nearest DTV to be the destination when a DVCR is being controlled as 

10 source to eliminate having to select the DTV each time. A background cross- 
referencing of the Stream Default Name to 1394 address is provided. The video stream 
services are provided by the 1394 interface itself (not by Web model). As such there is 
a linkage of the default source or sink to the 1394 address mechanism. The user can 
access a device and select a name for default, which is then saved on the device. The 

15 device's software agent must find the 1394 address and parameters for the 1 394 s/w to 
enable the default stream when required. 

Using the Source and Destination service attributes, new server/services can be 
implemented while maintaining compatibility with existing host or device (nodes) and 

20 services. For example, if a new server device providing a new service is developed that 
is compatible with an existing server device, both the new and existing serviers can be 
added to the attribute list of the new node while maintaining compatibility with existing 
nodes using the existing server in the network 100. The user can select a compatible 
device for purchase. These provide a user with "ABOUT" information to check 

25 capabilities of existing equipment e.g. prior to purchasing new equipment where 
compatibility is desired. 
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Network Operation 

A discovery process for every device supporting the 1394WEB standard (e.g. 
devices capable of displaying a user interface) gathers device information from devices 
connected to the network 100 to generate the top-level user control page description for 

5 the home network, wherein each device is represented by a graphical icon reference 
and a textual name reference detailed above. The top-level description can include a 
default page for a presentation engine such as the browser 200, wherein the browser 
200 collects the graphic images and names from the devices as it renders the network 
top-level graphical user interface 220 (GUI) displayed in the browser 200 as shown by 

10 example in FIGS. 5-6. The dynamically created top-level HN directory page 220 is 
made the default page for the browser (first page displayed when the browser is 
launched). 

With reference to FIG. 4b, example operation steps include: (1) the browser 200 
15 in device 102 is launched, (2) the browser 200 fetches and presents HN-Directory HTM 
(Top-Level Ul) from the page 204, (3) the browser 200 fetches the HTM files icon. htm 
and names.htm from pages 202, 204 and presents in the Top-Level Ul, (4) the browser 
200 fetches any graphics files (e.g., GIF) from pages 202, 204, and presents in Top- 
Level Ul, (5) the browser 200 is then able to present the full HN_Directory page 220 
20 (page 220 is made with hyperlinks to INDEX. HTM 1 files for different devices connected 
to the network 100), and (6) when a user clicks e.g. DVCR icon in GUI 220 to control 
the DVCR 110, a corresponding hyperlink in the top-level page 220 to 'INDEX.HTM 1 of 
the DVCR 110 is used to retrieve the 'INDEX.HTM' (top control page of DVCR) from 
page 202 in the DVCR 110, and present the DVCR control page to the user (e.g., if the 
25 frame that was clicked (e.g. the icon. htm frame) is not large enough, a graphic is 
presented in another copy of the browser with full frame size). The user can then 
command and control the DVCR 110 using the control interface provided by 
INDEX.HTM 1 of the DVCR device 110 presented by the browser 200 in the DTV 102 
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The name MNDEX.HTM' is arbitrary because the ICON. HTM and NAME. HTM are 
made with hyperlinks to the 'INDEX.HTM'. However, ICON.HTM and LOGO. HTM 
reference the actual graphics files (e.g. LOGO.GIF and ICON. GIF) in the same devices. 
In one embodiment, LOGO. HTM can be optional if a logo for a device is optional. The 
5 HNJDirectory HTML file can have a standard name so that it can be accessed from 
another device. 

FIGS. 5-6 show that the host device, such as a client device (e.g., DTV 102, 
HDTV1) or server device (e.g., DVCR 110) that generates and presents the top-level 

10 GUI page 220 can assume priority and use a larger size icon for the host device's icon, 
name, logo, etc. In one version, only devices with servers (services on offer) are 
displayed in the GUI 220 (a "Client device" comprises device with Client capability, 
where if it is only client then it is not displayed in the top-level GUI as there is no service 
to offer). The discovery process reads information from the 1394 address space data 

15 storage (configuration ROM structure), as defined in clause 8 of ISO/IEC 13213. 
Although called 'ROM' it is assumed that the address space is write-able to allow user 
configuration and modification of user relevant stored values. The contents of the 
configuration ROM and the discovery process are described further below. 

20 Device naming, addressing and discovery processes for home or local network 

control of consumer devices using Internet, Web and 1394 technology, can be different 
from the requirements and practice in the general Internet space. As such according 
to an aspect of the present invention for in home or local network control of consumer 
devices, special processes including device discovery, addressing and naming 

25 requirements are utilized. For example, the home network must fully function without 
the presence of external communications and services, without a network administrator, 
and configuration must be fully automatic. User control can be in many cases entirely 
keyboard-less. Further, the IEEE1394 protocol is utilized to provide a sophisticated 
interface including features that can be provide simple, efficient and superior discovery 
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and configuration functions. 



1 394 Home Network 

FIG. 7 shows a block diagram of a network 300 constructed in accordance with 

5 another embodiment of the present invention. To facilitate understanding, identical 
reference numerals have been used, where possible, to designate identical elements 
that are common throughout all the figures herein. As depicted in FIG. 7, a 1394 serial 
bus 114, described above, electronically connects multiple devices including server 
devices 14 (e.g., DVD 108, DVCR 110) and client devices 12 (e.g., DTV 102) on the 

10 network 100, described above in reference to FIG. 2, wherein the devices communicate 
using the example layered interface model of FIG. 3 as described above. 

The network 300 is not restricted to using a 1394 serial bus, and, in alternative 
embodiments of the present invention, other bus types, such a Ethernet, ATM wireless, 

15 etc., can be used as the physical layer if they meet the particular throughput 

requirements of an individual network (e.g., a home network) . As depicted in FIG. 7, 
the network 300 includes several devices connected to the 1394 serial bus 1 14. In this 
example, the devices include a DBSS 104 for receiving transmission signal from a 
satellite 122 for subsequent display. Associated with the DBSS is a network interface 

20 unit ("NIU") which, among other things, provides an interface between the DBSS 

satellite transmission and the 1394 serial bus 114. A digital video device (DVD) 108 is 
also connected to the exemplary network 300. The DVD 108 can be used to source 
digitally encoded videos for display on e.g. a digital television. Also connected to the 
exemplary network 100 is a digital video cassette recorder (DVCR) 110, a digital TV 

25 (DTV)102. In this example, the DTV 102 provides a human interface for the network 
300 by employing browser technology to allow users to control and command for 
devices over the home network 300. A second DTV 103 provides another human 
interface for the network 100 by employing browser technology to allow users to control 
and command for devices over the home network 100. The DTVs 102 and 103 can 
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requirements and prevents 'running out of IPV4' addresses. The external network can 
include e.g. CABLE-TV network 115 via Ethernet to the telephone e.g. ADSL), providing 
broadband connection to the Internet and WWW. The Ethernet 119 provides the bridge 
function to the external network. The bridge 1 17 or Ethernet 119 may provide the NAT 
5 address conversion function. If the Ethernet is to provide local private (to home only) 
addressing (e.g. as defined by then IETF standard RFC 1918) then the NAT function is 
in the Ethernet 119. Existing cable modems are set up with a global address and also 
Internet global address for the PC on the Ethernet (in this case the NAT is in the bridge 
117). 

10 

IP Name/Address Configuration 

The aforementioned device naming, addressing and discovery processes for the 
network 300 are now described. For device naming, point and click Web operation 
(e.g., using GUI/Web) does not require name services (DNS, Domain Name Service). 

15 The Web GUI provides an abstraction layer, and the addresses are hidden as hyper- 
text links invoked by user 'clicks' to active GUI areas (e.g., buttons). Any change to the 
devices in the local network 300 causes the top-ievel discovery GUI page 200 (FIGS. 5- 
6) to be recreated by the browser 200 (FIGS. 4a-b) representing the status of the 
devices in the network 300 at that time and by default presented to the user for 

20 immediate use. 

For device to device control a different look-up service is utilized for more than 
names (e.g., service look-up and application look-up). As such, DNS may not provide 
the necessary features for device to device control. However, a device (e.g., a 1394 
25 connected PC) can access a DNS service as usual. DNS is not required for discovery 
or operation of devices/services within the home, but DNS (name to address) look-up 
service is required for external accesses e.g. from a PC. When a name e.g. 
"www.yahoo.com" is typed in to a Browser then look up take place for the IP address of 
the Yahoo computer, i.e. 216.32.74.52, because the Internet (even home Internet) 
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operates with addresses. 



For a 775WEB Ul device which includes an agent for generating the HN top-level 
directory GUI description and also includes access to the special company web server 
5 e.g. homewideweb.com (IP address), can also have the DNS address knowledge. The 
DNS server computer IP address can be any IP address under the control of the 
manufacturer. Effectively the DNS address is built-in to the device (or can be updated if 
the agent is made to be update-able and is later updated). 

10 For device addressing, in one embodiment of the invention, utilizing fixed IP 

addresses from a large address space can afford the simplest and most reliable 
network configuration, and the readily accessible ROM data space in the1394 interface 
allows utilization of fixed IP addresses therein. In another embodiment of the invention, 
non-fixed IP (dynamic) addresses can be utilized, wherein an abstraction layer (e.g., 

15 name or look-up mechanism) is employed to retain pre-organized communications 

For IP address configuration, the following protocols can be utilized: (1) Dynamic 
Host Configuration Protocol (DHCP) with DHCP servers and DHCP clients, (2) DHCP 
clients resort to auto-configuration (DHCP server not present), and (3) preferably, 
20 , FWHCP (Fire-Wire Host Configuration Protocol) server agent(s) and FWHCP clients, 
described further below. The auto-configuration in (2) above is that proposed as an 
IETF Draft H draft-ietf-dhc-ipv4-autoconfig-04.txt n . 

DHCP requires support of the BOOTP/UDP protocol, and replicates what is done 
25 within the 1394 specification and provides features such as lease time and dynamic 
addressing. Typical DHCP requires management by an administrator and must be 
configured and adapted to the network requirements of mass manufactured consumer 
electronics (CE) appliances where, for example, multiple identical CE appliances with 
DHCP server built-ins must be considered. 
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provide human interfaces for the network 300 as each DTV comprises a screen for 
displaying HTML pages. However other devices having display capability can be used 
to provide human interfaces. Thus, in certain embodiments of the invention, a device 
such as a personal computer 105 (PC) is used to provide a human interface for a 
5 respective home network, as a PC 105 typically embodies a screen display unit. 

The 1394 serial bus 114 is depicted as using the HTTP/IP interface protocol, and 
preferably HTTP/TCP/IP, wherein IP provides packet format (a one-way write only 
model), TCP provides an error free version of IP (e.g., ensures packets arrive and in 

10 correct order), and HTTP provides 2-way connection (packet to server will expect a 
response -a 'read 1 model). Certain devices can require other protocol interface types 
(e.g., TCP/IP, UPD/iP, FTP/IPJELNET/IP, SNMP/IP, DNS/IP, SMTP/IP). In certain 
embodiments of the invention, a proxy 116 can be used to interface two networks using 
dissimilar interface protocols on their respective mediums which, when connected, 

15 comprise the network 300. 

For example, as depicted in FIG. 7, the 1394 serial bus 114 using the HTTP/IP 
interface protocol is connected by a proxy 1 16 to the Home Automation network 118 
(e.g., X10). By using the proxy 1 16 as HTML/HTTP/CTP/IP/1394 proxy for VCR- 
20 Commands/AVC/FCP/1394, to interface between HTML/HTTP/TCP/IP and X10 
protocols, DVCR 120 is also accessible on the network 300. 

In this embodiment, the network 300 can be connected to an external network 
1 19 of dissimilar type (e.g., Ethernet) to the 1394 Serial bus, via a bus 121 . A proxy 
25 1 17 is used to interface the two dissimilar medium types. For communication between 
the addressing scheme of the external network 119, and the addressing scheme of the 
network 300, the bridge 117 comprises a Network Address Translation (NAT) boundary. 
This technique can be utilized for company LAN's and is a "divide and conquer* 
approach to the complex problem of satisfying various network's differing IP address 
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The 1394 technology provides 'Plug-in' or 'Power-up' reset and following f Self-ID' 
sequences, well suited for network configuration. Further, the 1394 specification 
provides a built-in 'ROM' address space well suited for storage of, and access to, 
configuration data (e.g., IP addresses). As such, in a preferred embodiment of the 
5 invention, an IP address configuration agent (FWHCP) and discovery page for user 
control of 1394 devices are utilized. FWHCP provides IP address configuration for 
1394WEB and 1394 devices. The purpose and result of FWHCP is similar to DHCP 
(i.e., a server to identify and assign the local IP addresses), but in operation FWHCP 
uses data in 1394-address space and 1394 commands. FWHCP provides IP address 
10 configuration of 1394WEB devices on the 1394 network avoiding collisions with devices 
on adjacent attached networks other than 1394. Devices are manufactured with a built- 
in IP address from the 10.x.x.x range. In the unlikely event of a collision, FWHCP sets a 
new IP address and saves it in the device. 

15 DHCP/Auto-configuration can be utilized for devices on networks other than 

1394. DHCP protocol provides client "requested IP address". Preferably, the 
requested IP address space is selected from the upper part of the 24 bit RFC191 8 
range (10.128.1.1 to 10.254.254.254). By choosing part of the allowed private address 
range for 1394 IP addresses and another part for other configuration methods (e.g., 

20 DHCP and DHCP/Auto-Configuration) then compatible and non-interfering addresses 
are generated for a heterogeneous network and allow FWHCP and DHCP to coexist. 

While choice of non-overlapping IP addresses for 1394 and adjacent networks is 
desirable, the heterogeneous network using FWHCP will configure successfully even if 
25 they do overlap. Also, DHCP clients check their assigned IP address with a test ARP 
message before using it. As such, different address configuration methods can coexist 
successfully. 
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Network Scenarios and Address Management 

Referring to FIG. 8, an example process according to the present invention for 
communication between a 1394 network (e.g., network 300) and a non-1394 network 
(e.g., Ethernet 119) for IP address configuration is described. In this case the 1394 
5 network 300 utilizes FWHCP configuration and the non-1394 network 119 utilizes 
DHCP configuration or other method. Generally, 1394 devices (such as DTV and 
DVCR in FIG. 7) do not support DHCP. The 1394 DEVICE-3, for 1394 network to non- 
1394 network communication, includes an IP address in the 1394 ROM space and 
provides support for FWHCP for a 1 394 device. The DEVICE-3 further includes means 

10 for supporting the configuration mechanisms on the non-1394 network, and maintains 
an extension data leaf in the 1394 ROM space for IP addresses of devices on the non- 
1394 network. As such, configuration processes (e.g., FWHCP for top-level Ul 
description generation) on the 1394 network 300 can include use of IP addresses on 
the non-1 394 network by selecting IP addresses from the extension data leaf. The 

1 5 non-1 394 network configuration operates to provide the IP addresses for the 1 394 
extension data leaf. 

According to the discovery process (agent), 1394 specification 'plug-in' reset and 
self-ID is utilized for configuration and can be used for IP address configuration. 

20 Preferably, fixed IP addressing is utilized for home networks, however dynamic IP 
addressing can also be utilized. DNS is not required within 1394WEB control because 
a top-level GUI description is created with hypertext-links that use IP addresses rather 
than names. Preferably, the IP configuration agent (FWHCP) for the 1394 network is 
utilized for IP configuration using 1394 ROM data and 1394 commands, however DHCP 

25 can also be utilized. FWHCP utilizes lower half of RFC1918 10.LH.X.X addresses and 
other home networks (not 1 394) use upper half 1 0.UH.X.X. Preferably, the FWHCP 
server agent is built-in to any device that can be a client (control initiator). Where there 
are several client devices connected to the 1394 network, only the client device with 
the highest Global Unique Identification (GUID) operates. GUID comprises a number 
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built-in to the interface. If there are multiple FWHCP agents available on the 1394WEB 
network then there is an initial self-election process to determine the one that will 
operate and all others remain quiet. The highest GUID will operate. In other versions, 
highest bit-reversed-GUID can be used. 

5 

A device interfacing to a non-1394 network supports a ROM extension leaf of IP 
addresses on the non-1394 network. This allows inclusion of the IP addresses on the 
non-1394 network in the 1394 top-level GUIs (e.g., FIGS. 4a-b, GUIs 202, 204). 
Control data bits in the 1394 ROM space are used to control the operation of three 
10 configuration agents: (1) 1394 SelfJD count, (2) IP configuration FWHCP, and (3) Ul 
description generation described further below. 

Initially 1394 Self-ID count discovers the existence of devices. After a bus reset 
(caused by power up/down or device attachment/detachment) 1394 software in the 

15 device observes the automatic configuration process (1394 self-ID cycles) for the 

purpose of counting the number devices. This is a normal part of 1394 software for any 
1394 device. Then, IP Configuration FWHCP (the one self -elected FWHCP) probes 
the discovered devices and checks their built-in IP address. Discovered duplicate 
(colliding) IP addresses are disabled and a new address is assigned to the device. 

20 Then, Ul description generation agent (Ul or other devices), reads all 1394WEB device 
IP addresses and generates a top-level device directory Graphic User Interface file in 
HTML of top-level icon pages from each device later rendered by a Web browser for 
User discovery of devices for control. 

25 According to the present invention each device in the 1 394 network 400 can 

generate its own top-level network Ul description 250 (FIG. 9c). The Ul description 250 
is used by a presentation engine such as the browser 200 in a client device to generate 
and display a top level directory page such as page 220 in FIGS. 5-6. After the 1394 
Self-ID agent has enumerated all devices connected to the 1394 network 300, the top- 



33 



level Ul description 250 is generated separately by all Ul devices (and non-UI devices 
as desired). A device (e.g., DTV) can select a more prominent (e.g., larger) icon to 
represent that device, and make the entire GUI 220 with a different look. This 
technique provides substantially more reliable operation than a centrally generated GUI 
5 for operation of all device, because each device can generate its own Ul description 
250 and display a GUI (e.g., top level page 220) based thereon without dependence on 
another device. In each Ul description 250, device icon and logo image files of the 
devices currently connected to the network 300 are referenced by icon and logo HTML 
'pages' and name text wrapped in an HTML page (ICON. 'Graphic' referenced 
10 ICON. HTM is in pages 202 and 204 which also include the control pages for the 
device; Fig. 5 below also shows the ICON.HTM, LOGO. HTM and NAME.HTM in a top- 
level directory page). HTML frames are used to create the top-level directory Ul 
description 250 for network devices in each network device as desired. 



15 As such, advantageously, a useful layer of abstraction is provided to allow use of 

alternative file names and types for e.g. identification graphics in the network devices 
without need for change in the top-level description 250 generated in each device. The 
name text is also placed in an HTML description 202, 204 (NAME.HTM is in pages 202, 
204), allowing a user to configure the name text at a device e.g. DTV to change to e.g., 

20 DTV-BED2 through one of the device GUI pages 220. As such, the page 220 is 
displayed as the Browser is launched after a reset. The user sees and clicks DVCR 
ICON graphic, whereby DVCR top level control GUI 202 is fetched (with 'Play' button 
etc.). User clicks one of the buttons e.g. "Configure Device NAME" which is another 
GUI (of hierarchy of control pages for DVCR) with a large selection of different names. 

25 User clicks one name out of the lists of names provided e.g. "Master Bedroom DVCR". 
Software on the device changes the file names so that the file named NAME.HTM 
contains the text "Master Bedroom DVCR" (the old default NAME.HTM file that 
contained DVCR is changed to some other name). 
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Appearance of the GUI 220 is more stable in the event of 'bad citizen' devices 
having too much or oversized text or oversized logos. In this case the frames isolate the 
problem and prevent the bad items from adversely affecting the appearance of the 
entire top-level GUI 220. 

5 

Device Discovery Architecture 

Referring to FIGS. 9a-c, 10, 1 1 example functional blocks and connections to 
data and control bits and flowchart of an embodiment of a system architecture 400 for 
the aforementioned discovery process are shown. The system 400 comprises five 

10 primary elements: (1)1394 non-volatile memory space (IEEE1212R ROM) 402 for 
configuration data and control data bit storage; (2)1394 Device Discovery Agent 
(1394DDA) 404; (3) IP Address Configuration Agent (FWHCP) 406; (4) Ul Description 
Generation Agent 408; and (5) GUI Generation and run-time environment 410 (e.g., 
Web Browser 200 in FIG. 2). Further, FIG. 10 shows an example flow diagram for the 

15 DDA and FWHCP agents in system 400 operating in connection with the functional 
blocks in FIGS. 9a-c. And, FIG. 10 shows an example flow diagram for the UIDGA 
agent in system 400 operating in connection with the functional blocks in FIGS. 9a-c. 

Referring to FIGS. 9a and 10 all devices include the 1394 device discovery agent 
20 (1394DDA) 404 to enumerate the devices on the 1394 bus, after a reset, and to write 
the value into the local 1394 ROM space 402 for communicating the value to other 
functional agents (steps 500, 502). For synchronizing (inhibiting) commencement of 
other configuration agents, the 1394DDA agent 404 also sets the 'configuration 
operating' control bits . The discovery agent/mechanism can use means, other than the 
25 ROM space, to communicate information between the configuration agents that are 
local to one device and where the information does not need to be seen by other 
devices. 
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1394 ROM Data in all Devices 

All devices in the network 300 include the following information relevant to the 
discovery and IP address agents 404 and 406, respectively, for thel 394WEB in the 
1394 configuration ROM 402: (1) Built-in 64 bit GUID (Global Unique ID, in 1394 
5 specification); (2) Built-in IP address from the RFC 1918 private address space in the 
range '10.1.1.1' to '10.127.254.254'. Manufacturers can select a value from the GUID 
such that chance of collision is minimized. The upper portion of the private address 
space (i.e., 10.128.1.1 to 10.254.254.254) is reserved for devices on bridged networks; 
(3) Assigned IP address in the range '10.1.1.1' to '10.127.254.254' (assigned by 
10 operating FWHCP agent 406); (4) IP address extension leaf for IP devices on bridged 
networks; (5) Assigned Count of 1394 devices (assigned by 1394DDA agent 404); (6) 
Control/status bits to indicate Configuration-in-Progress Synchronization control for 
1394 Device Discovery Agent 404, and to indicate IP-Address configuration (The 
control bits indicate the configuration is in progress and therefore the values, in ROM 
1 5 data other than the control bits, for 1 394DDA and IP address are not checked or not 
written and therefore should not be used). The bits further indicate which IP address is 
valid (assigned or built-in), and whether an FWHCP server agent 406 is present in the 
device; (7) HTTP web server to allow files in the device's file space to be accessed 
remotely; and (8) device information 202, 204 including actual 'icon', 'name' and 'logo' 
20 HTML files and other referenced graphic files accessible through the Web Server. The 
above summarized information is detailed in the 1394 ROM space description below. 

IEEE 1212 Config ur ation ROM 

The content of the general 1394ROM structure 402 is specified in IEEE1212r, 
25 IEEE1212 and IEC61883. The ROM structure 402 is a hierarchy of information blocks, 
wherein the blocks higher in the hierarchy point to the blocks beneath them. The 
location of the initial blocks is fixed while other entries are vendor dependent, but can 
be specified by entries within the higher blocks. 
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Table 3 shows the BusJnfo_Block and RootJDirectory of the configuration ROM 
402. The first byte of each entry is known as a key and identifies the type of entry. The 
following can be implemented in the configuration ROM of all devices making use of the 
EIA-775 specifications, including display devices such as DTVs and source devices 

5 such as DVCRs, STBs, etc. There may be several other structures required based on 
other protocols to which each device conforms. Table 3 includes information for a 
device which also complies with the IEC61883 protocol. The Root_directory contains 
pointers to a Model_J)irectory and three Unit_Directory entries (IEC61883, EIA-775 and 
1394WEB), to indicate that the device supports EIA-775 as well as 1394WEB 

10 protocols. The Root directory entries are useful to other 1394 devices to discover the 
protocols and software (also called services) supported by this 1394 device. 
Table 3 — Configuration ROM 



15 



20 



Offset (Base address FFFF F000 0000) 
Bus info block 



Offset 



04 00 16 | 04 | crcjength | rom_crc_value 



*1$ 



04 04 16 


"1394" 








04 08 1S 


flags 


reserved 


cyc_clk_ac 


max_rec I reserve 








c 


|d 



vendor id 



chip_id_hi 



Wherein, 04 0C 16 and 04 10 16 are also known as the 64 bit GUID or Global 
25 Unique ID. 
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10 



Offset 



XX XX 



Rootjfirectory 



| Q4 14 1R I rootjength 



CRC 



Optional 



C3 



Modet_Directory offset 



□ 







model vendor id 




81 w 


vendor name textual descriptor offset 




0C 1R 


node capabilities 




8D 1R 


node unique id offset 






Unit Directory offset (IEC 61883) 




D1 w 


Unit Directory offset (EIA-775) 




D1« 


Unit Directory offset (1394WEB) 



The IEC_61883 unit directory is shown in Table 5. This directory is referenced 
by the Unit_Directory offset, in the Root Directory (i.e., Table 3). In the 

15 Unit_SW_Version field, the least significant bit specifies AV/C (0) as specified in IEC 
61883. 



Table 5 — IEC_61883 Unit Directory 

Unit_Directory (IEC_61883) 



directory length 



CRC 



20 



1216 


Unit_SpecJD (1394TA = 00 AO 2D 16 ) 


1316 


Unit_SW_Version (first pass key - 01 16 ) 




«possibly other fields» 







25 The EIA-775 Unit Directory is shown in Table 6. The following EIA-775 specific 

information appears in the EIA-775 Unit Directory. 
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Table 6 — E1A-775 Unit Directory 



1 

1216 


Unit specification JD (EIA-775 - 005068 16 ) 


13 w 


Unit_software_version (010100 16 ) 




«possibly other fields» 







The Unit_specification_ID specifies the identity of the organization responsible 
for the architectural interface of the device and the specification. In this example case, 
the directory and identity value=005068 16 refers to the EIA as the responsible body and 
10 the EIA-775 control architecture specification. 

The Unit_software_version designates EIA-775 revision level supported by the device. 
The format is shown in Table 7. 
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Table 7 — Unit_software_version coding 



First octet 



Second octet 
Third octet 



01 



16 



Major Version Number (currently 01 16 ) 
Minor Version Number (currently 00^) 



20 The 1394WEB Unit Directory is shown in Table 7a. The following 1394 WEB 

specific information appears in the 1394WEB Unit Directory. 
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Table 7a — 1394WEB Unit Directory 



5 



i directory length 


CRC I 


1210 


Unit enor*ifir>atinn ID M ^Q4WFB = OOXXXX,^ 


1316 


Unit software version (010100^) 






3816 


Discovery control bits 


3916 


Assigned Count_of_1394_devices 


3A, R 


IP Address Built in 


3B 1R 


IP_Address_Assigned 




IP Address Extension Leaf 


-16 


«possibiy other fields» 



The Unit__specificationJD specifies the identity of the organization responsible 
for the architectural interface of the unit and the specification. In this example case the 
15 directory and identity vaIue=00XXXX 16 refers to the responsible body and the 1394WEB 
control architecture specification. 
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The Unit_software_version designates the 1394WEB revision level supported by 
the device. The format is shown in Table 8. 



Table 8 — Unit_software_version coding 



25 



First octet 



Second octet 
Third octet 



01 



Major Version Number (currently 01 16 ) 
Minor Version Number (currently 00 iR ) 



Discovery control bits (38 1g ) 

Key value (38 16 ) permitted by the IEEE1212R specification section 8.8 for the 
private use by the owner of the directory and architecture is used for the 
30 Discovery_control_bits immediate value. 
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Table 9 — Discovery_controLbits 











FWHCP 


Configuration 


Which IP 










Server 


operating. Do not use 


address? 










Agent 


(if True) 




X 








Yes=1 


1394 Dev. IP- 
Count Address 


Assignd_1 
Built-inJ) 


31 


6 


5 


4 


3 


2 1 


0 (LSB) 



5 

These are control bits in 1394 ROM space 402 accessible by local and remote 
device. The control bits are used by the IP address configuration agent 406 and the 
User Interface description generation agent 408 as described further below. 



10 In one embodiment of the invention, said control bits provide the following 

information: 

Bit 0 - Which IP address - Indicates which IP address is used or is in-use i.e, the 
Bulit-ln address (=FALSE) or Assigned Address (=TRUE). This is set by the operating 
15 IP configuration agent FWHCP 406. 

Bits 1,2- Configuration Operating Do not use - When set indicate that the 1394 
device discovery and also, seperately, the IP configuration agents 404 and 406, 
respectively, are operating and therefore the values referred to are invalid as they can 
20 change or are not yet written. These bits are set by the local (device) 1 394DDA agent 
404. The1394DDA agent 404 clears the 1394 Dev. Count bit and the operating 
FWHCP agent 406 clears the IP-address bit. 

Bit 3 - Presence of FWHCP Server Agent 406 - Is set if the device has an operable 
FWHCP agent 406. This bit and GUID are used by the FWHCP agents 406 to determine which 
25 FWHCP agent 406 will operate. 
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Assigned_Count_of_1394_devices (39 16 ) - Assigned immediate value of the 
count of 1394 devices in the network 300. The count is made as the 1394 interface 
goes though its self-ID cycles. The 1394 device discovery agent 404 generates the 
value, which is saved in ROM space 403 for subsequent use by the IP and Ul 
configuration agents 406 and 408, respectively. 

IP_Address_Built_Jn (3A 16 ) - Assigned Immediate Value. This address is 
assigned at manufacture time and built-in to the device. If this Built-in address cannot 
be used, an alternative address can be saved in the Assigned address space and the 
control bit set to indicate such. 

IP_Address_Assigned (3B 16 ) - Assigned Immediate Value. If identical IP 
addresses are detected, the IP address configuration agent FWHCP 406 assigns this 
address to prevent collision. Further, the control bit is set to indicate such. 

IP_Address_Extension Leaf_for_attached_network (BC 16 ) - This directory entry 
is for the address offset to the data leaf for the IP address extension table, see Table 
10. The data leaf contains IP addresses for devices on connected non-1394 networks 
(but also could be bridged 1394 networks). The table is included in communications 
devices of types (e.g., bridge) that connect through to foreign (non-1394) networks. 
The table can be expanded to include as many IP addresses as required. The address 
of the communications device itself should not be included in the table. 



Table 10 — IP_Address_Extension Leaf 



Leaf Length -1 (n) , R [ CRC-Te 



_!£_ 

IP Address ~ 



IP Address n 



42 



In regards to Control word for Discovery Control Bits, use of a ROM entry for the 
actual Discovery Control Bits word as defined herein works but is an example 
implementation. As ROM is not designed to be written efficiently (i.e., ROM areas have 
to be erased and writing them is slow relative to other hardware e.g. register). 
5 Registers are provided in the 1394 hardware for data that must be written to frequently. 
In another version, a 1394 Register can be used for the 'Discovery_control_bits' control 
word. Registers are in a space also addressable by other devices, whereby another 
device can look up in the ROM the address of the Register and then write to that 
Register. 

10 

Referring Figure 9b, one or more devices include an IP address configuration 
agent (FWHCP) 406 (e.g., all Ul devices and Gateway devices and any other device 
that can be a Control initiator). The FWHCP configuration agent 406 accesses all 
devices' IP address values in data in the1394 ROM 402 across the 1394 network 300. 
1 5 For synchronization commencement and completion of commencement of other 

applications (e.g., the Ul description generation), the FWHCP agent 406 also accesses 
the 'configuration operating' control bits. 



Referring to Figure 9c, devices capable of displaying user interfaces, and also 
20 some other devices (e.g., Gateway devices), can include the Ul description generation 
agent 408 for generating the top-level Ul description 250 in e.g. HTML. Because as 
detailed above only one IP configuration agent 406 operates per network 300, not all 
devices need to include the IP configuration agent 406, though all devices can include 
an IP configuration agent 406. If a device has the operating IP Configuration Agent 406 
25 and is a User Interface Device then the IP configuration agent should operate before 
the Ul Description Generation agent. The Ul description generation agent (UIDGA) 408 
utilizes information including control bits defined in the1394 ROM space 402 and other 
information (e.g., for determining which FWHCP operates is the Global Unique ID 
(GUID) of Bus_lnfo_Block of Table 3) for determining which IP configuration agent 406 
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(if multiple in the network) operates, synchronizing commencement and for access to 
the in-use IP addresses. Any device may have and operate a UIDGA for making the 
HN_Directory page (top-level discovery page). After the IP addresses are configured 
UIDGA reads the addresses to make the HN_Directory page. In each client device, 
5 when Ul description generation is complete, the GUI generation and run-time 

environment 410 (e.g., Web Browser 200 in FIG. 2) uses the Ul description HTML file 
250 to access all devices' HTTP file space for icons, names and logos (Icon. HTM, 
Name.HTM and Logo.HTM are contained in pages 204, and 204) to generate the full 
top-level GUI 220 for display in that client device. Web Browser uses HTML file 250 to 
10 render the actual GUI graphics, in the process accessing files from the devices e.g. 
Icon.HTM, Name.HTM and Logo.HTM and in turn accessing any additional files these 
files reference e.g. ICON.GIF and LOGO.GIF. 



1394 Device Discovery Agent (1394DDA^ 

15 Referring to FIGS. 9a-c, 10 as discussed, each 1394WEB device in the network 

300 can include the device discovery agent 404. The device discovery agent 404 
enumerates the 1394 devices in 1394 address space connected to the 1394 bus, 
wherein the raw discovery is performed in 1394 hardware. The SelfJD and Physical 
Node Number Assignment and the steps leading to it is the basic discovery process 

20 performed by the interface hardware/firmware. All devices monitor the SelfJD cycles 
and make a note of the existence of 1394 devices. This is a part of 1394 software for 
any 1394 device: (1) Reset -Bus reset propagates to all interfaces, on device power-up, 
device attachment and device detachment, (2) Tree Identification -Transforms a simple 
net topology into a tree, to establish a ROOT which is master for certain functions: Bus 

25 Cycle Master, Highest priority in arbitration for bus time, (3) Self Identification -Assigns 
Physical Node number (address) and also exchange speed capabilities with neighbors. 
Highest numbered node with both Contender Bit and Link-on Bit is Isochronous 
Resource Manager. 
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The discovery agent 404 writes the final count value of the devices to the 1394 
ROM space to communicate it to other agents. The device discovery agent 404 is the 
first software agent to execute after a 1394 reset cycle, and control bits (Discovery 
Control Bits 2 and 1, Configuration Operating: 1394DDA, and IP_Address) are used to 
5 delay other agents, including the configuration agents 406 and 408, from execution until 
the discovery agent 404 has finished execution. 

In one embodiment, the1394DDA agent 404 in each device performs the steps 
500, 502 including: (1) setting synchronization control bits (i.e.,'1394DDA in progress' 

10 and 'IP configuration in progress' bits) in the device's own 1394 ROM space 402 to 
indicate that the 1394DDA in progress and IP configuration is in progress (IP 
configuration will not be in progress if 1394 DDA is executing) and that the values of 
1394 device count and IP address are not valid, whereby said control bits inhibit other 
agents (e.g., 408) from operating prematurely; as such the 1394 DDA executes, then 

15 an elected FWHCP executes, and then (usually for Ul device) UIDGA executes; (2) 
counting the number of 1394 self-identity sequences after a 1394 Reset to discover the 
number of devices and effectively their local node addresses for use by the other 
agents 406, 408; (3) writing the device count value to the device's own 1394 ROM 
space 402; and (4) clearing (e.g., to false) the synchronization control bit for '1394DDA 

20 in progress' in the device's own 1394 ROM 402, wherein the 'IP configuration in 
progress' bit remains set and is cleared later by the operating FWHCP agent 406. 

Alternative Architecture for Configuration with IP Address list in network 
communication (bridge) device is possible. For example, the IP address list of IP 
25 addresses of devices on a bridged (e.g., non-1394 network) can alternatively be 

examined at the IP configuration stage by the FWHCP agent 406 rather than only at the 
UIDGA stage by the UIDGA agent 408. This allows the FWHCP agent 406 to detect 
and correct address collisions and therefore allow operation without having two 
separately defined address ranges, one for the 1394 network 300 and one for the non- 
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1394 network 119. Correction of address collision can be accomplished by modifying 
the address of a colliding 1394 device as the bridged network IP address list cannot be 
modified by the aforementioned agents 406, 408 for the 1394 network 300. 
Configuration is more reliable if the FWHCP agent 406 can check the addresses in the 
5 bridged network 1 1 9 for collision prior to allowing the addresses used on the 1394 
network 300. 



IP Address Configuration Agent (FWHCP Agent) 

Referring to FIGS 9a-c, 10 the IP Address Configuration software agent 

10 (FWHCP) 406, operates to provide 'Fixed' IP address management and to detect and 
correct IP address clashes in the mass manufactured 1394 devices. All 1394WEB Ul 
devices include, and other devices can include, an FWHCP agent 406. Only one 
FWHCP agent 406 operates in the network however. The 1394DDA 404 agent is the 
first software agent to execute after a 1394 reset cycle, and as aforementioned 

15 the1394DDA 404 agent sets the '1394DDA in progress' and 'IP configuration in 
progress' bits to delay the FWHCP agent 406 until the 1394DDA agent 404 has 
executed to completion. 



In one embodiment, the IP Address configuration agent 406 in a device performs 
20 steps including polling the 1394DDA configuration operation control bit (i.e., the 
'1394DDA in progress' bit) to determine if the 1394DDA configuration software agent 
404 has executed to completion. If so, then the FWHCP agent 406 uses the count of 
devices determined by the 1394 DDA agent 404, and reads GUID's and Control Words 
from every device (step 504) to determine which device in the network 300 is selected 
25 to execute its FWHCP agent 406 (step 506). The selected device is one with an 
FWHCP agent 406 that finds it has the highest GUID (step 508). All other FWHCP 
agents 406 in other devices remain dormant (step 510). The operating FWHCP agent 
406 reads the 'in-use' (active) IP address (determined by Discovery_controLbits BIT 0) 
from each local node (e.g. units present on the interface, host) and listed (step 512) In 
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one version, the software agent makes a list for saving the IP addresses to an 'Array' as 
they are read (steps 514-518). The list will be in memory (RAM or DRAM) under the 
control of the compiler and OS. In-use status is determined by a bit setting in the 
device, which indicates whether the built-in or assigned address is in-use. In Table 7 
5 the IP_address_assigned and IP_address_built_in are in the 1394Web Unit Directory. 



The operating FWHCP agent 406 examines said list for collision among IP 
addresses listed therein (other collision detection and resolution methods can also be 
used) (steps 520-522). If a collision is detected, the FWHCP agent alters the colliding 

10 addresses by e.g. substituting the least significant 6 bits of IP address for their 6 bit 
node address (step 524). Only the minimum number of alterations are performed to 
relieve the collision. If one of the colliding addresses is already an assigned address, 
then that address is altered in preference to the colliding built-in address by e.g. 
incrementing the 6 bit substitute value and re-checking until the collision is resolved. 

15 The FWHCP agent 406 writes the altered value back to the device and the control bit 
(Discovery_Control_Bits: Bit 0) is set to indicate that the assigned IP address is in-use, 
and the built-in default is no longer in-use (step 526). The process is repeated for each 
IP address (step 528). After the collision resolution process, the operating FWHCP 
agent 406 accesses each device in turn and sets the 'IP configuration in-progress' bits 

20 in each device to e.g. 'false' to indicate that the indicated IP address is valid. 



Ul Description Generation Agent 

In conventional WWW operation, users access the same top level page. 
Referring to FIGS. 4b, 7 and 9-11, according to an aspect of the present invention 
however, all Ul devices (e.g., devices capable of displaying user interfaces) include an 
Ul description generation agent (UIDGA) 408 to independently generate a top-level Ul 
page 220 for control of the devices on the local network (e.g., network 100, network 
300, etc.) by users. In one example, a client device (e.g., PC) dynamically generates a 
locally saved default page 220 for user control of devices connected to the network 
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100. This allows each Ul device (e.g., DTV 102) to generate a different view 220 of the 
home network e.g. with a larger more prominent icon for that Ul's devices displayed. 
As such, the user is readily made aware of which Ul device is 'right here' (in front of the 
user) or in the case of access external to the home, no device is 'right here'. A device 
5 without a Ul can generate a Ul for another device but is unaware of type of device (e.g., 
Cable Modem generates Ul of HN devices for user external to the home). In this case 
the actual Ul device is unknown. Therefore no particular device is prominent in the GUI. 
Further, manufacturers of devices connected to the network 100 can provide their own 
GUI design 202, 204 in each device as desired. In addition later, improved Browser 
10 and Web technology designs need not be hampered by existing technology. 

Non-UI devices, particularly those devices performing a gateway function, can 
also include a Ul Description Generation agent 408 to generate top-level GUI 
descriptions 250, without including GUI Generation and Run-Time processes 410 (e.g., 

15 Web Browser 200) to generate and display GUIs 220. With appropriate address use 
(e.g., using the RFC1918 private addresses on the local HN), this allows external 
WWW access to the 1394WEB network devices.. External addresses are assigned 
'real' IP addresses suitable for Internet use. Generally there is a unit (e.g., gateway type 
unit) with the UIDGA 408 which represents the home to the outside Internet. The 

20 gateway's UIDGA generates a different Ul description for the outside use (remote 
access case different from inside local device use), using the home's IP address with 
extended links to identify which home device local private IP address. 

Ul devices execute the following software processes to generate and display 
25 views 220 of the network 1 00/300: (1 ) 1 394 Device Discovery Agent 404 described 
above, (2) Ul Description Generation Agent (UIDGA) 408, and (3) GUI Generation and 
Run-Time (e.g., Web Browser 200) process 410. Referring to FIG. 11, in one 
embodiment, a UIDGA agent 408 in a device performs steps including polling the IP 
address configuration bits in the device's own 1394 ROM 402 to ensure completion of 
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the FWHCP agent 406, prior to accessing any further IP information (step 600). Upon 
completion of FWHCP agent 406, using the count of devices generated by the 
1394DDA agent 404, the UIDGA agent 408 then accesses the control word in each 
device currently connected to the network, to determine the settings for the 
5 'configuration operating' false, and 'in-use' IP addresses bits (the UIDGA agent 408 
makes the top-level HTML page, HN_Directory page, 220 shown by e.g., in FIGS. 5-6). 
Thereafter, the UIDGA agent 408 reads the actual in-use IP address value, and builds a 
complete list of the IP addresses of the devices currently connected to the network 300. 
The IP address list includes information (e.g., Icon, Logo, Name, etc.) from every 

10 device, and is written in HTML by using the IP address of each device . Before it can 
include the addresses, the UIDGA 408 finds the address of each device by accessing 
each device and checking to see which address is in use by reading Table 9, 
Discovery_control_bit, control bit (Bit 0). Then UIDGA 408 reads Table 7 Address either 
Builtjn or Assigned. For devices that communicate to bridged networks, as determined 

15 by the presence of the extension IP address list entry in that device's 1 394 ROM 402, 
the UIDGA agent 408 reads the extension IP-addresses from the list 
(IP_Address_Extension_Leaf) to allow those devices to be included in the GUI 220. 
The entry BC (IP_Address_Extension_Leaf ) contains a reference link address that 
points to the actual data leaf. Devices on the attached bridged network are only 

20 included in the IP_Address_Extension_Leaf list if they also support the 1 394WEB type 
of service i.e. they have Web Server and lcon.HTM etc and Control pages ('index.htm). 

The UIDGA agent 408 reads the IP address list (step 602) and generates the 
top-level network Ul description 250 (FIG. 9c) in e.g. HTML (e.g., Appendix 1) using the 
25 IP address list (UIDGA outputs the HN_Directory, top-level network Ul page, HTML file) 
(step 604). The UIDGA agent 408 uses the IP Addresses in the hypertext links to each 
device for the icon.htm, name.htm and logo.htm files. UIDGA writes an HTML file 
including the references to each discovered device's HTML page i.e. ICON.HTM, 
NAME.HTM, LOGO.HTM (e.g., Appendix 2, 3, 4). The UIDGA agent 408 then uses 
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HTML files to reference items including the icon and logo graphics files and name data, 
rather than including the raw icon.gif or logo.gif and raw name text in the top level Ul 
description 250 (step 606). This allows said items to be changed by the corresponding 
device to reflect current status, customized by the manufacturer or configured by the 
5 user at the device, without causing any change in the top-level HTML Ul description 
250 in the controlling Ul device. Though one graphic per device is shown in the 
example GUI pages 220 (FIGS. 5-6), customization allows inclusion of more than one 
graphic file referenced by ICON. HTM or LOGO. HTM and more text in the NAME. HTM. 
In one embodiment, HTML frames are utilized to implement the Ul description 250 as 

10 showing in examples further below. Use of frames stabilizes the appearance of the GUI 
220 in the event of 'bad citizen' devices. For example a device presenting too many 
words or overly large text in its 'name' frame will only affect that device's GUI look (by 
having some of the words truncated and not displayed) and not adversely affect the 
appearance of the whole Top-level GUI 220 in the Ul device. The UIDGA then invokes 

15 the GUI generation process 410 (e.g., browser) in a client device to generate and 
display a user interface (step 608). 



GUI Generation and Run-Time Processes 

The GUI generation process 410 (e.g., Web Browser 200) utilizes the Ul 

20 description 250 in e.g. HTML to generate GUI pages 220 on Ul devices. In one 
example, to provide keyboard-less operation for consumer electronics devices (e.g., 
DTV) the Browser 200 at start-up defaults to reading and rendering a locally generated 
'top-level-devices.html' description 250 to generate the network top-level control GUI 
220. Locally as used here means in the same device (a Ul device having a UIDGA that 

25 generates the device's own HN Directory (top-level) GUI of the network devices). HN 
Directory, Top level Network Ul and Discovery page are the same. For personal 
computers (PC) with keyboard this need not be the default. For CE devices, launch of 
the Browser 200 is delayed until after completion of the UIDGA default page 250 
generation by the UIDGA agent 408. In the event that UIDGA agent 408 cannot 
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complete its tasks, then the Browser 200 displays an alternative UI page 220 showing a 
network configuration error occurred (e.g., "Unable to generate the HN_Directory Page 
because of xxxxxx. Try disconnecting device xxxxxxx. Network configuration error 
number xxxxxx occurred. Contact service Tel service xxx-xxx-xxxx or Web service 
5 http://www.service.com.") 



To generate the GUI 220, the Browser 200 fetches the 'icon.htm', 'name.htm' 
and 'logo.htm' files from device information 202, 204 in each referenced device (i.e., in 
the UI description, where for example ICON.HTM is in the HN_Directory Page HTML 
10 file) as defined by the HTML UI description 250. The contents of these pages 202, 204 
(e.g. the icon graphic) need not be static and can be altered dynamically to reflect 
device status change, or after user customization. In order to display the most current 
top-level page 220, the Browser 200 does not cache the 'icon.htm', 'name.htm' and 
'logo.htm' files. In another version, a check is always made first to determine if the 
15 device has made any changes to the HTML files 202, 204 it holds. HTTP "Conditional 
get" is used for checking the status of controlled device. Depending on the status code 
returned, the Browser 200 will either read from its cache or fetch a fresh or updated 
copy the HTML file 202, 204 from the devices. The HWW GUI display is not affected 
unless there is any change of the status of the controlled device. 

20 

The browser 200 does not attempt to display the top-level HN directory until it 
has been completely generated. If the HTML 250 is not generated within some 
reasonable amount of time, the browser displays an alternate page. If a network 
configuration error is the source of the problem, the alternate page might provide some 
25 technical support or user diagnostic assistance. 

Whenever the user returns to the top-level HN directory or causes it to be 
refreshed, the browser 200 redisplays the page 220 in its entirety. This is necessary 
because the HTML 250 that underlies the top-level HN directory may have been 
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regenerated if a device has been added to or removed from the network 100. It is also 
possible for device icons to be updated to reflect changes in their device's operating 
state. As such, browsers implemented by EIA-775.1 devices use HTTP "conditional 
get" requests to determine whether or not fresh copies of web pages or graphics are 
5 retrieved from the server. 



In this aspect, the present invention provides a User Interface description where 
user discovery of devices is thus made entirely with references (i.e. in the abstract), 
where the references are 'containers' for the discovery information (e.g., text and/or 
10 graphics) of each device and resident on each device. Each 'container' includes actual 
textual information and/or references to one or more graphics formatted information 
files where each file may include one or more images and/or text. Use of the reference 
'containers' allows each device to choose its preferred Ul content or graphics format or 
alter its Ul content to be displayed (by changing the text or graphic information referred 
15 to) without need to have the Ul description page altered in any way. Therefore, 
communication of changes with the generating agent software of the Discovery Ul 
description is not required. In one version, devices reference their e.g. ICON and 
LOGO graphics files indirectly using HTML files enabled by creating the network Top- 
level description using HTML frames. Similarly the device name that is displayed under 
20 the icon is represented by NAME HTML file. HTML files are used to reference e.g. the 
icon and logo graphics files and name data rather than include the raw icon.gif or 
logo.gif and raw name text. This allows the item to be changed to reflect current status, 
customized by the manufacturer or user configured at the device without causing any 
change in the top-level HTML description. This level of abstraction allows the Top-level 
55 Ul description to be always the same regardless of the graphics ICON and LOGO file 
names and types and NAME text to be displayed. Also the device may use different, 
multiple or dynamically change the graphics files and text displayed in the Top-level 
GUI without the change needing to be communicated to the UIDGA. The change is 
automatically included whenever the GUI is redisplayed. Use of frames also stabilizes 
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the GUI display in the event of bad citizen devices using non-displayabie graphics or 
text as the error is confined to the particular frame and doesn't affect the whole GUI. 
The change is automatically included whenever the GUI is redisplayed. 

5 Referring to Appendices 1-4, illustrative examples for the following are provided: 

(1) Top-Level Page description 250 (Appendix 1); (2) Background.htm (Appendix 2); (3) 
Icon. htm (Appendix 4); and (4) Name.htm (Appendix4). 

Although the present invention has been described in considerable detail with 
10 regard to the preferred versions thereof, other versions are possible. Therefore, the 
appended claims should not be limited to the descriptions of the preferred versions 
contained herein. 
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What is claimed is: 



CLAIMS 



1 . A method for providing a user interface for controlling devices that are 
currently connected to a network, the method comprising the steps of: 

for at least one of said devices: 

5 

(a) obtaining information from one or more of the devices 
currently connected to the network, said information including device 
information; and 

10 (b) generating a user interface description based at least on the 

obtained information, the user interface description including a reference 
associated with the device information of each of said devices currently 
connected to the network, such that the reference includes at least one 
link to information contained in said devices currently connected to the 

15 network. 

2. The method of claim 1 , wherein the step (b) further includes the steps of 
generating the user interface description such that the reference in the user interface 
description provides access to at least the information in each corresponding device. 

3. The method of claim 1 , wherein the step (b) further includes the steps of 
generating the user interface description such that the user interface description further 
includes device data corresponding to each device based on the information obtained 
from each device. 
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4. The method of claim 1 , wherein the step (b) of generating the user 
interface description further includes the steps of associating a hyper-text link with the 
device information of each of said devices currently connected to the network. 

5. The method of claim 1 , wherein said information in each device comprises 
an HTML page contained in that device. 

6. The method of claim 1 , wherein the device information in each device 
includes device identification information. 



7. The method of claim 1 , wherein the device information in each device 
includes a user control interface description for user interaction with the device. 

8. The method of claim 7, wherein the step (b) further includes the steps of 
generating the user interface description such that each reference in the user interface 
description is to at least the user control interface description in each corresponding 
device. 



9. The method of claim 7, wherein the step (b) further includes the steps of 
generating the user interface description such that the user interface description further 
includes device data corresponding to each device based on the information obtained 
from each device, the device data providing reference to the user control interface 
description in each device. 



1 0. A network system for performing a service, comprising: 

a physical layer, wherein the physical layer provides a communication 
medium than can be used by devices to communicate with each other; 
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5 one or more devices connected to the physical layer, each device storing 

information including device information; 

an agent in at least one device for: 

10 (a) obtaining information from one or more of the devices 

currently connected to the network, said information including device 
information; and 

(b) generating a user interface description based at least on the 
15 obtained information, the user interface description including a reference 

associated with the device information of each of said devices currently 
connected to the network, such that the reference includes at least one 
link to information contained in said devices currently connected to the 
network. 

1 1 . The network system of claim 10 wherein the agent generates the user 
interface description such that the reference in the user interface description provides 
access to at least the information in each corresponding device. 

12. The network system of claim 10, wherein the agent generates the user 
interface description such that the user interface description further includes device 
data corresponding to each device based on the information obtained from each 
device. 

13. The network system of claim 10, wherein the agent further associates a 
hyper-text link in the user interface description with the device information of each of 
said devices currently connected to the network. 
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14. The network system of claim 10, wherein said information in each device 
comprises an HTML page contained in that device. 

15. The network system of claim 10, wherein the device information in each 
device includes device identification information. 

16. The network system of claim 10, wherein the device information in each 
device includes a user control interface description for user interaction with the device. 

17. The network system of claim 16, wherein the agent generates the user 
interface description such that each reference in the user interface description is to at 
least the user control interface description in each corresponding device. 

18. The network system of claim 16, wherein the agent generates the user 
interface description such that the user interface description further includes device 
data corresponding to each device based on the information obtained from each 
device, the device data providing reference to the user control interface description in 

5 each device. 

19. The network system of claim 10 further comprising means for generating 
at least one user interface by: using each reference in a user interface description to 
access the information in each corresponding device, and generating the user interface 
including device data corresponding to each device using the accessed information in 

5 each device. 
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20. 



A network system for performing a service, comprising: 



a physical layer, wherein the physical layer provides a communication 
medium than can be used by devices to communicate with each other; 

5 

multiple devices connected to the physical layer, one or more of said 
multiple devices storing information including device information, and one or more of 
said multiple devices each including an agent for: 



10 (a) obtaining information from one or more of the devices 

currently connected to the network, said information including device 
information; and 



(b) generating a user interface description based at least on the 
obtained information, the user interface description including a reference 
associated with the device information of each of said devices currently 
connected to the network, such that the reference includes at least one 
link to information contained in said devices currently connected to the 
network. 



21 . The network system of claim 20, wherein each agent generates a user 
interface description such that the reference in the user interface description provides 
access to at least the information in each corresponding device. 

22. The network system of claim 20, wherein each agent generates a user 
interface description such that the user interface description further includes device 
data corresponding to each device based on the information obtained from each 
device. 
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23. The network system of claim 20, wherein each agent further associates a 
hyper-text link in a user interface description with the device information of each of said 
devices currently connected to the network. 

24. The network system of claim 20, wherein said information in each device 
comprises an HTML page contained in that device. 

25. The network system of claim 20, wherein the device information in each 
device includes device identification information. 



26. The network system of claim 20, wherein the device information in each 
device includes a user control interface description for user interaction with the device. 

27. The network system of claim 26, wherein each agent generates the user 
interface description such that each reference in the user interface description is to at 
least the user control interface description in each corresponding device. 

28. The network system of claim 26, wherein each agent generates the user 
interface description such that the user interface description further includes device 
data corresponding to each device based on the information obtained from each 
device, the device data providing reference to the user control interface description in 
each device. 
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Abstract 



A method and system for providing a user interface for a user to discover and 
control devices that are currently connected to a network, such that at least one of said 
devices performs steps including: (a) obtaining information from one or more of the 
devices currently connected to the network, said information including device 
5 information; and (b) generating a user interface description based at least on the 
obtained information, the user interface description including a reference associated 
with the device information of each of said devices currently connected to the network, 
such that the reference includes at least one link to information contained in said 
devices currently connected to the network. As such, a user interface can be displayed 
10 using the references in the user interface description, for controlling said devices 
currently connected to the network. 
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A ppendix 1- Top-Level Page Example 

<HTML> 
<HEAD> 

<TITLE>HN Devices Page</TITLE> 
</HEAD> 

5 

<FRAMESET ROWS="2%, 47%,2%, 22.5%,2%,22.5%, 2%" border=0 color=black> 
<NOFRAMES>Sorry does not support frames</NOFRAMES> 
<FRAMESET ROWS="100%,0%"> 
<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
10 </FRAMESET> 

<FRAMESET COLS= B 1.2%,23.5%,1.2%,48.2% l 1.2%,23.5% > 1.2% ,, > 
<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
15 <FRAMESET ROWS= , '48%,4%,48%"> 
<FRAMESET ROWS="73%, 27%"> 
<FRAME SRC="http://10.1.1.1/icon.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.1.1.1/name.htm" SCROLL!NG="no" NORESIZE> 
</FRAMESET> 
20 <FRAMESETROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
<FRAMESET ROWS="73%, 27%" > 

<FRAME SRC=" http://10.1.1.10/icon.htm" SCROLLING="no" NORESIZE> 
25 <FRAME SRC=" http://10.1.1.10/name.htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 
</FRAMESET> 

<FRAMESET ROWS="1 00%,0%"> 
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<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 

<FRAME SRC=" http://10.1.22.1/icon.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.1.22.1/name.htm■ , SCROLLING="no" NORESlZE> 

</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="48%,4%,48%"> 

<FRAMESET ROWS="73%, 27%" > 

<FRAME SRC=" http://10.1.229.1/icon.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.1.229.1/name.htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 
<FRAMESET ROWS="73%, 27%" > 

<FRAME SRC=" http://1 0.30.30. 1/icon.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http.7/10.30.30.1/name.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
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<FRAMESET COLS="1 .2%,23.5%,1 .2%,23.5%,1 .2%,23.5%,1 .2%,23.5%,1 .2%"> 
<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
<FRAME SRC=" http://10.41.1.1/icon.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.41. 1.1 /name. htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 

<FRAME SRC=" http://10.41. 21. 1/icon. htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.41. 21. 1/name.htm" SCROLLING="no" NORES!ZE> 

</FRAMESET> 

<FRAMESET ROWS="1 00%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
< FRAME SRC=" http://10.45. 1.1 /icon. htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://10.45. 1.1 /name. htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
< FRAME SRC=" http://10.100.1.1/icon.htm" SCROLL!NG="no" NORESIZE> 
<FRAME SRC=" http://10.100.1.1/name.htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 
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<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 

</FRAMESET> 
</FRAMESET> 
5 <FRAMESETROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET COLS="1.2% i 23.5% i 1.2%,23.5% 1 1.2%,23.5%,1.2%,23.5% > 1.2%"> 
<FRAMESET ROWS="100%,0%"> 
10 <FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
<FRAME SRC=" http://10.122.22.1/eia.htm" SCROLLING="no" NORESIZE> 
<FRAME SRC=" http://1 0.1 22.22. 1/eia.htm" SCROLLING="no" NORESIZE> 
15 </FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
20 <FRAME SRC=" http://10.122.122.122/icon.htm" SCROLLING="no" 

NORESIZE> 

<FRAME SRC=" http://10.122.122.122/name.htm" SCROLLING="no" 
NORESIZE> 

</FRAMESET> 
25 < FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 
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<FRAME SRC=" http://10.122.122.123/icon.htm" SCROLLING="no" 
NORES!ZE> 

<FRAME SRC=" http://10.122.122.123/name.htm" SCROLLING="no" 
NORESIZE> 
5 </FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

<FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

<FRAMESET ROWS="73%, 27%" > 

10 <FRAME SRC=" http://10.122.122.124/icon.htm" SCROLLING="no" 

NORESIZE> 

<FRAME SRC=" http://10.122.122.124/name.htm" SCROLLING="no" 
NORESIZE> 

</FRAMESET> 

1 5 <FRAMESET ROWS="1 00%,0%"> 

< FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 
</FRAMESET> 

<FRAMESET ROWS="100%,0%"> 

20 <FRAME SRC="background.htm" SCROLLING="no" NORESIZE> 
</FRAMESET> 

</FRAMESET> 

<BODY BGCOLOR="#FFFFF0" TEXT="#000070" LINK="#00O0fT ALINK="#FF0000" 
VLINK="#007986"> "rruuuu 

25 </BODY> 

</HTML> 
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A ppendix 2- Background.htm example 

<HTML> 
<HEAD> 

<TITLE>Background</TITLE> 
5 </HEAD><BODY BGCOLOR="#007986"></BODY> 

</HTML> 
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A ppendix 3 - lcon.htm example 

<HTML> 
<HEAD> 

<TITLE>Device lcon</TITLE> 
5 </HEAD> 

<BODY BGCOLOR="#FFFFF0" TEXT="#000070" LINK="#0000ff' ALINK= n #FF0000" 
VLINK="#007986"> 
<br><br><CENTER> 
10 <IMG SRC="icon.gif border=0> 
</CENTER> 
</BODY> 

</HTML> 
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A ppendix 4 - Name.htm example 

<HTML> 
<HEAD> 

<TITLE>Device Name</TITLE> 
5 </HEAD> 

<BODY BGCOLOR="#FFFFF0" TEXT="#000070" LINK="#0000ff' ALINK="#FFOOOO" 
VLINK="#007986"> 

<CENTER><FONT size=+0>Samsung Device</font></CENTER> 
10 </BODY> 
</HTML> 
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